











































































+ . ‘ te <2 a ax y Po, ey 78 . yor 
55 . 4K . . . is re Ff ee fy 
2 ae + . ans hoy Rs a *. 
a i . ‘ ‘ > < Cones 
F oe ~ . ’ . ‘ < 
+ . ’ > ‘ - ant 
# os wy SON es Sy, Par : os ‘NS 
e . ‘aes . an % x ed a Scart se 
‘ 
* “s woe ’ ’ : ¢ MS a Re eo ee ‘ 5 
’ 
2 . 7 oe ” “ Root - Meno wt “8 we ’ 
“ > ‘ » % > . . $ 
He 3 . : eA > Phage ty tues ot ie el 
ne + nN . iS ‘ = * ag 
A . . x ’ om ; . € . 
. . . rs . . cn 
4 as dots . = 
Ra ¢ * ? . Sa 
we : fe . ws ~ es . 
. . < x 
é ae % Satay S . . . oS s x SNe EN ay Be tes 
s ee a wy ’ ve a < fe we ee fee eh oe _ BRE ae 
é 5 > ‘ . , ? vo 2 
% vooe rong . 
. aN soo MN 5 3 $ ‘ os wet 
¥ a % 5 » Sa < oe ~ Fak Soyeww x Fs Picken UN as ty ooo oe . 
> . . ? vas . * * < ve ‘ “ 
“ 
. % . we ‘ * z + “3 < 
3 5 rs . . : . + s . . sows os “ 
% > 7 + * * “ . > $ eR 
. % 
’ ‘ ie Pe Some eo 6 
Z ’ ’ ‘ & » ’ oo ’ ‘ vie . ‘ 
« coe xe 
- ye ey BTS . rs ‘ a woe + F 
Yo oe ane coe “ ’ ° ’ 3 a : 
’ ’ ’ p> be e ‘ . rae; eoe “e 
, ’ 
’ ¢ ’ . <2? 
. ‘ ” * ’ . 
% gs 5 5 575g ? x a oe ran 4 
. ‘ * . : . “ “ ee . 
. aos . “ ss s San oe aay 4 # 
Rog ¢ . ‘ . Nf . bi ~ * “st sat 
. ¥ . BS broN o> > 
Pans wy ¢ . . EF % 
7 a ‘ . > s x 4 a 
_ rd 7 : rots . woe too a § 
é x . . as 
- ’ ‘ . Oe 9 ’ 
% + . s 4 . , 
s ~ ‘S S y . Nos wy . a 
. bs yO BE ORS cars Bess at yt . Boss 
7 . . oe . wes . er nt 
: Z s . “ 
£ a j a? # wee 
. a ’ 
Sp s s : . % SMa. We “Uy we aes 4 nN ws u 
wf YP ‘ 7 * ¢ * . 
, . . ‘ wn xt 2 es ans 
4 rae * reo, eos . “oe - eek et v ve : 
cet fs ‘ N ‘ . “ . s s wit fs s s 
os ~ : . > * eae rears * ya 
’ ‘ ‘ . 
wy ’ 7 ‘ ‘ ’ be ¢ 
+ 4 . . * . > > + > 
wt ee a ‘ * Mgt) ede os fy gan ts 
et Metad a? ‘ te oy v <? 0 % 
< . . ™ 
: ee * * ‘ * ‘ > “a ee e . 
* 
Z $ NOONAN x x . 
5 * . . + ‘ s 
. Sed . 3 fy Sot < 
? 
ny ° * 4 . ‘ Fete PSS % 
. ‘ Ms . Noy . . mo 
‘ ’ + , 7 > ’ 4 
2 “ ee : ¢ ’ ye + ’ + 
5 nee ee . 4 Pi ay 
an . . . bee eg % . 
any 
, é > Peat Sa 
. ‘ ’ ‘ se 
NON . . “Ss i bd 
. ’ . . wt ’ . 
’ . 
4 * ¢ . at ee s 
‘ . x eae 
a a * . . 
’ . 
Fs ’ 3 Pas , a 
‘ ‘ ‘ « 
> % . 
i we x ‘ 
Beg as apt ¢ _ 
wy ey ’ ’ 24 
a opi ak Laon wee baw wae fae baw wah oe a 
STFS g g ‘ x ‘ x z 
Ps Pay ‘ ’ a . a 
* . LP soot 
5 z 2 gk xf lw : a soe 
. 
, eee Ne wv? ’ “” Oheehone ’ ’ ‘ oy. ¢ re eee oe 
< . Agr Re . < ate a 
‘ ‘ 4 s “ + soos w ON vos % 
Ramey : ny oR Big ST . 
. po ¢ . . 
‘ . ’ fe > + 
: + 2 oe: ra vey ss ie > . 
a Pan 3 $ NY ’ > A ‘ 
“ > £ se “ a 
: Hs 2 ys . % why s a Syog 
we ss sows . * sys wos s ‘ 
. . soe cf ¢ om . at co 
ee Je Sashes . Gh ee : » SES 
wos «s : * “ ws woes S ° NON we Ae Bay x 
wy a te ke RE Peg a 8 oe Set ay TS REE og Sy Ee 
os % ‘ . es Btw WR TO OR og NS y SVS foo. 
e 2 o 5 ? : 
eee “ *. 7 $ ’ 3 tas ony. 
> ak a 8s ‘ . Teeth ’ Ns ne eee 
” J ee ‘ 7 pag, Ae. 
‘ . . . s $ > * 
os x : ‘ s x . ‘ 
‘ ” ’ > . - rs - 
s aot y Re ee ‘ wh c ‘c S ‘ . Es 
‘ . ‘ S . $ ‘ * ny . L, at 
Parte ta ar 6% a . . “ ‘ o By . Nos > 
4 “ & . 4 
Ay wo ¥ Fe x * ‘ ss . ‘ 
‘ . « 
. ‘ foo. an ‘ MB sg? oh 
. ie eS Y ones “ane sone ae ie 
’ é , . 
a kt ’ 3 ’ 
. . ’ 
o ’ 2 . . 
ve % 2 : 
. ” 
‘ > . 
7 oe 
‘ “ . > fs . 
’ “ ’ ? . 
eg hS * = 
. . Sa 
‘ * : “ 
“ * . 
fan “ 7 i ‘ ha 
‘ : yoy ¢ ’ yok > > 
. ‘ Fae “ 
. % : a 
rs . > ‘ > ; ‘s . . ’ 
’ . ’ - ’ os 
oN ‘ bi ’ . * 7 - . ’ 
. i . * * ae on ’ 
. * ‘ ‘ : . 
“ a i . . . a OS 
SF “ ett Ey ‘ 
~ ‘ > 
’ 2 ’ 7 : 4 . a 
= “ “ . <. y ‘ s 6 
¢ . es ‘ é . rs 
ae . . oe ~ 
s ’ > € 
“ ai > “ ‘ s : . > . s 
. Yous “ ’ : ’ ’ . ae 
¢ . ‘ . 
see wae ow tele ~ ~ ‘ ¢ - . 
i ? : ‘ ‘ Z a 9 Me Mey 
a gabe Pagets . 3 o : ae Pe OS, PO 
aoe ° ei s % . Ww OF ori 
‘ vot 2 . . 43 * . oo4? ee: 
” a ‘ ’ ’ . be ‘ + Cee 
an ‘ ’ ‘ . 4 oo 
‘ > ‘ . ’ ‘ ase ‘ te 
a . 
> % : ” ‘ i ecg Of . me, See. OER 
” . : * ‘ = . . . é 
* ‘a s 2 ’ , 7 s ed 
¢ . ’ a “ i 4 + 7 
oo feos < ooo. ek a * . ace “ 
. . ’ . 
- > g a 3 $ > ” = 
: s ‘ ‘ ’ ’ 
‘ re . . _ 
AOR Aran tate + . bons 
aH oo ¢ Fy ¢ 
’ ° ‘ ‘ > . 
’ ’ e+e ¥ 
Ps ee FR = wot 
. o 
r 
¥ P ‘ ane af o, Se ’ 
‘ $ = 
‘ “ 
rad . bd .s Noe 
‘ y > > . 
oe . 
“ ’ : ’ 
. 
‘ . . 
* - . 
pA A ke age “ ‘ Ad aw nn vane PC wtn we - 
7M ON: 
’ » ’ ‘ 
‘ ‘ 4 
Se ‘ ‘ ‘ anes ° 1% $ 
ae get - a x x 
‘ . - 
. ’ 
‘ sow . sa et 
“ ’ 
¢ ahs ete 
. 3 ‘ 
¢ we, i 5 - 
. . “ ey . Pe 
’ ’ . ‘ 
; a ‘ ‘ . ‘ “ 
“ “ 2 . ve 
mn . 
Ps ’ 
0 . 3 < . as 
re ’ 
‘ 3 ¢ < 
“ “ ‘ ‘ 
‘ ’ - ‘ . . 
* * a % N ee 
an ’ ’ Sa 7 : - . 
‘ ’ ’ . ‘ 
~ ae be 
s 
o cS ae ic ’ 
’ . 
. e thee 3 s . 2 . 
“ 5 “ . 
" . 
‘ > he <3 
‘ ans ’ 
“ ’ z 
“ * Ay + A oe, we wten ge” 
TO Gagne 28 . . , > bars 4 
: 5 ors ’ ’ . ’ ‘ x . 
. . . 
ie “ 2 x . ore ae 
‘ . 
awe wf me 2 aes 
! % ere AE 
ar ee ‘ Pi he 
a . woe ’ c Pe ase 
. . Spat 
ae ee 3 ea 
A 7 ¢ % e oy ¢ 
so yee et . . 
4 . . ° Led 
ae 
as whe 4 f a . 
oye . , Meet 
wo. aa 4 SHR 
. , 7 ae 
x e, > . 
oe . “ . ve 
. 
‘ . 
‘ ~ ’ ’ . . * 24 
‘ - Fy é > 
‘ 
: ae - 5 Ste 
’ . oo 3 
’ ws ¥ . eons 
a 44% ¢ . as 
. ‘sf . . by x 
eRe “ . ay pte 
’ a oS ’ . Dak So Somes 
“ . ’ . xy 
A ‘ > ’ 
ae ¥ ‘ a ge ahora ios Sa 
4 . <4 
. pot 7 « % 
: 
ou a0 Ry “ - os - 
. fie ©? Pe 1 ee 
. > a ae 
$1 ’ noe 
.* . a 
. ‘ : At og 
Li , 7 . ’ ‘ oo 
. . %, . 
: ’ . ’ 2 8 . 
. * * se 
. 7 - . . aed 
. * . , . 
eee 
. x “oy ‘ é oe ’ bias 
ce ’ + ee 
‘ : . 
we ‘ ’ ad 28 Geet 
‘ Casa 4 : ’ s ’ roa 
e sd oe ef . 53 8 ¢ 
Py °: . to, te 
. eof as 
“ “i “ te .o# Sige Ox ae 
“” a - ae 
‘ 3 a 
7 sow ao + 
+ ¢ . ‘ an. 
ae . . oe ba 
oat . aa Dae 
. . on 
. * Pingo 
a eR els Moc as on ehee’ ses he Soe Lee ie a 
Be ’ . 3 S Ye > 
a . soe . ¢ > id ’ Pt 
: < 4% 
. a ‘ ’ eee oe 
. ’ ” . tae teehee, Pr as 
+ > ’ ’ . ? wo ar 
. Pa ‘ ~ a . ry 
+ * ’ eat. ra 
. . ‘ cs - . ? wwe 
‘ . 4 + . of > ¢ ee ate ca ¥ 
s ass . ote 
‘ ’ : faners % rs 
‘ hee OOS ‘ £ ty 
. . : ane 
. “ o “ . . . ¢ wo, i 
s . . * eet . 
Fa troy 3 
’ * ’ “ 
“ toe 
. ’ < a 
> x . + ’ Ne, ¥ 
7 ‘ ’ ee hs ’ ’ 
“f 4 g $ e ’ . 
. . x ‘ . 
e ‘ > . * . . ‘ ’ poe ee 
. 
he ’ > . ’ 
. ‘e ‘ . . a * ‘ . + 
’ me Ng. doe ae « : : 
‘ oo” . . ‘ . ty som L 
ee ay i otk ‘ 2 + : 
. a * ’ . a . se 
. 7 x oo eo fpa tN 
t ‘ . es 2S fogs 2 x hoe ees A awe, . 
oe ’ ‘ Yo ’ ce tog te 
’ on ‘ oo¢ ’ a Ce wee ae * : 
Fr “ % . . é < * tio. 
. som ‘ ‘ Avie een sep ok poe Ran a anne * ad of Bats ed Sree 
. im S ~ z TT 
: as ¥ ees 2 ’ , * . ‘ xt att . 
rae nee ¢ fod ; - * ee ’ ‘ ve - 
’ ’ “ Sg ee ? , 7 
‘ a x s “ . ww oe ty 
. vee is “ vos gee 
0 ’ . e284 
: - # ee ’ ’ . toa een: + . Gee se 2 
* - at ra 2 a = : 4 
- ’ ~ he ’ ts. f ‘ pea > : Syke 
¢ r ’ ’ ? . * ae . 
oe x . ra ¢ Fe we 8 weet oo 
i ’ cae 3 s “ oF 
% . 7 % rr ae apd i ~ Paar ’ 
. . ’ . . r ee 
. 3 ne Pes . Hon hp . - By ’ a - aos a 
sek ‘ ey - ’ ’ 4 
ay 
¢ ee 7 ‘ 2 + a ete eS 
. . . . 7 eae 
. . * . Ny . aes se ’ - 2 
P + a9 ~ . of ec Ne 
‘ Pe Ey e ’ ’ > ten te Ee - + a 
ar 3 ‘ % wlio : . ? si 
é we . - 4 . “ < s Soe ” ge 
: ey ’ F os ope “ > ete rroes 
‘ vo, ¢ ’ A ’ . oe Be a oe ‘ a 
* f . it oft £ * 7 * 
nee f as, oy tee : af . ’ ns 
+ ‘ an ‘ ’ “ x * ‘ ‘ ’ 1 ¥ ’ a3 
4 ’ ’ oe eo. % ‘ en eofe¢ eos le 
“i z : és 2 3 2 pie sé ? 5a ers at : 
% a id + ’ aya ~ % 
* . ty ay ’ * be - te ws . % +t . * Pa 
pte ve ne we < i. ‘, e : ae Posy 
ve re coe ‘ ¢ % oe & . . . f 
‘ see ee z ‘ 2 eos oe ss os 
€ “ . . ws ~ ee RS og Oy v 
= . 
‘: “ > > = ’ 
. eo yo ofee > fe “. £ an 
See fie os 828 . a 3 , os 
y . soFey os - 8 ’ 7 
5 a te . 28 gia woe Be card fa 
_ 7 S 5 . % . we . ¢ “ 2 . a ? 
a * elie x s = 7 + % ee _ * “ Pa 3 
ae its % 2 x . ’ . he a - . 
= 7 . ° . ’ wt ‘s a . Bn OE LEE Re ae 
’ . . . ‘ ye an . “ x i . bas ah, = 
. oe » v8 . . £ ¢ ae . 
+ S . ws ‘ . a 
‘ . : . “ 3 o rs 
x ’ * woe + > ’ 
‘ “ 
. ‘ . toe a ’ + . 
3 ey 7 one 5 BOB . vos . we 
” ’ ak 7 vy ot + ete oe gre . 
at . e . ree vo ie ‘e er baw = 
ee ’ ’ ! - * a ~ f ~ “ey a 4 g . 


WD90C3TA 








TABLE OF CONTENTS 
Section Title Page 
1.0 INFRODUGTION: © ee le whic tes ha ae ee i. oe ee te KB oS SO + oe 
Vek: “SF@QMMNGS: oc. 8. em Boe me ee he ie ww Se ee 2 17-1 
1.2 General Description ........ 2... ee 17-2 
1.2.1 Hardware Cursor .......... 0.0.00 8 eee 17-2 
1.2.2 HardwareBITBLT ............... 2.004, Lie 
2.0 WD90C31AARCHITECTURE ............ 0... 2.2.00. 17-3 
3.0 WD90C31AINTERFACES ......... 2... ee ee 17-4 
3.1 CPUAnd BIOS ROM Interface ...............020. 17-4 
3.2 DRAMInterface ......... 2... 17-4 
3.3. Videolnterface ........ 2... 17-4 
3.4 ClocklInterface ... . ooo Sah OG os He Ba oe Ae Ae ae oe 17-5 
3.5 WD90C31A Power- sig Contigurailon: ee ee ee ee ee ee ee a 17-5 
4.0 SIGNALDESCRIPTION ...... . ee 17-7 
5.0 VGA/EGA REGISTERS: <« « «6.4 ¢6 VMS eed oe we Sa Se W720 
5.1 EGAModeEntry ............ 2... 2.6.4. 4... . 17-20 
5.2 General Registers .. . .. . 17-23 
5.2.1 Miscellaneous Output Reaisiee VGA - Read Port = = '3CCH, 
VGA/EGA- Write Port=3C2H .... _— J...) 17-283 
5.2.2 Input Status Register 0, Read Only Port = 3C2H ee ee ee ee ee 
5.2.3. Input Status Register 1, Read Only Port=3?AH ...... . 17-24 
5.2.4 Feature Control Register, VGA - Read Port = 3CAH, 
VGA/EGA- Write Pott=3?AH ..... be eo ee we Se. “Nee2S 
5.3. Sequencer Registers ... . 17-25 


5.3.1 Sequencer Index Aacister Read/Write Port = 3C4H - VGA/EGA 17-25 
5.3.2 Reset Register, Read/Write Port = 3C5H, Index = OOH - VGA/EGA_ 17-25 
5.3.3 Clocking Mode Register, Read/Write Port = 3C5H, Index =01H . 17-26 
5.3.4 Map Mask Register, Read/Write Port = 3C5H, 


Index =O2H-VGA/EGA... . . . . 17-26 

5.3.5 Character Map Select Register, Read/Write Port = 3C5H, 
Index =O3H_... . . 17-27 
5.3.6 Memory Mode Regist Read/Write Port = 8C5H, ee 04H . 17-28 
5.4 CRT Controller Registers ... . ut: FG ae wo | Teo 
5.4.1 CRT Register Index, Read/Write Pitts 324H_ a ae oe . 17-30 


5.4.2 Horizontal Total Register, Read/Write Port = 375H, Index = 00H . 17-30 
5.4.3 Horizontal Display Enable End Register, Read/Write Port = 375H, 


IndexO1H .... . . 17-30 
5.4.4 Start Horizontal Blanking Register. Read/Write Port = 35H, 

Index=O2H .... . 17-30 
5.4.5 End Horizontal Blanking, Read/Write Port = 35H, inde 03H . 17-30 





tf 9/3/92 17-i 


WD9O0C3IA 








Section Title Page 

5.4.6 Start Horizontal Retrace Pulse clea Read/Write Port = 375H, 

Index = 04H ocd 17-31 
5.4.7. — End Horizontal Retrace Rodisier ‘Read/Write Port = 35H, 

Index = 05H 17-31 
5.4.8 Vertical Total Register, Read/Write Port = 35H, eee 06H 17-32 
5.4.9 Overflow Vertical Register, Read/Write Port = 325H, Index = 07H 17-32 
5.4.10 Preset Row Scan Register, Read/Write Port = 375H, Index = 08H 17-33 
5.4.11 Maximum Scan Line Register, Read/Write Port = 3?75H, 

Index = 09H 17-33 
5.4.12 Block Cursor Start Register, Read/Write Port = = 75H, 

Index = OAH 17-34 
5.4.13 Block Cursor End Feclctor Read/Mrite Port = 35H, indexe OBH 17-34 
5.4.14 Start Address High Register, Read/Write Port = 375H, Index =OCH 17-35 
5.4.15 Start Address Low Register, Read/Write Port = 375H, Index=ODH 17-35 
5.4.16 Block Cursor Location High Register, Read/Write Port = 3?75H, 

Index = OEH ig of 17-35 
5.4.17 Block Cursor Location oui Register Read/Write Port = 395H, 

Index = OFH or 17-35 
5.4.18 Vertical Retrace Start Asalsien ‘ReadMrite Pott = = 395H, 

Index = 10H 17-35 
5.4.19 Vertical Retrace End Register Read/Write Port = = 325H, 

Index = 11H a 17-36 
5.4.20 Vertical Display Enable End Register, Read/Write Port = = 325H, 

Index = 12H Se He 17-37 
5.4.21 Offset Register, Read/Write Pott = 325H, snide = 43H 17-37 
5.4.22 Underline Location Register, Read/Write Port = 375H, 

Index = 14H 17-37 
5.4.23 Start Vertical Blank Register, Read/Write Port = = 325H, nda -15H 17-37 
5.4.24 End Vertical Blank Register, Read/Write Port = 375H, Index =16H 17-38 
5.4.25 CRT Mode Control Register, Read/Write Port = 375H, Index =17H 17-38 
5.4.26 Line Compare Register, Read/Write Port = 375H, Index = 18H 17-39 

5.5 Graphics Controller Registers 17-39 
5.5; Graphics Index Register, Read/Write Port = = 3CEH 17-39 
5.5.2 Set/Reset Register, Read/Write Port = 3CFH, Index = OOH 17-40 
5.5.3 Enable Set/Reset Register, Read/Write Port = 3CFH, Index=01H 17-40 
5.5.4 Color Compare Register, Read/Write Port = 3CFH, Index = 02H 17-41 
5.5.5 Data Rotate Register, Read/Write Port = 3CFH, Index = 03H 17-41 
5.5.6 Read Map Select Register, Read/Write Port = 3CFH, Index =O4H 17-42 
5.5.7. Graphics Mode Register, Read/Write Port = 3CFH, Index = 05H 17-42 
5.5.8 Miscellaneous Register, Read/Write Port = 3CFH, Index = 06H 17-44 
5.5.9 Color Don’t Care Register, Read/Write Port = 3CFH, Index = 07H 17-44 
5.5.10 Bit Mask Register, Read/Write Port = 3CFH, Index = 08H 17-44 
5.6 Attribute Controller Registers 17-45 
5.6.1 Attribute Index Register, ReadMrite Port = 3COH 17-45 
17-iI 9/3/92 


We 


WD90C3I1A 








Section Title Page 

5.6.2 VGA- Palette Registers, Read Port = 3C1H, Write Port = 3COH, 

Index 00-0FH 17-45 

5.6.3. EGA - Dynamic Color Aeaisiers Read Port = = 3C1H, 

Write Port = 3COH, Index 00-OFH 17-46 

5.6.4 — Attribute Mode Control Register, Read Port = 3C1 " 

Write Port = 3COH, Index = 10H 17-46 

5.6.5 Overscan Color Register, Read Port = 3C1H, Write Port = = 3COH, 

Index = 11H 17-47 

5.6.6 Color Plane Enable Resistor Read Port = = 3C1 H, Write Port = = 3COH, 

Index = 12H . . . 17-47 

5.6.7 Horizontal Pel Panning Register, Read Port = = 3C1 H. Write 

Port = 3COH, Index = 13H , ; 17-48 

5.6.8 Color Select Register, Read Port = 3C1 "| Write pits 3COH, 

Index = 14H ge ae A , : = 17-49 

5.7 Video RAMDAC Ports 17-49 

6.0 COMPATIBILITY REGISTERS , 17-50 
6.1. Hercules/MDA Mode Control ic MDA A Operation 

Write Only Port = 3B8H , 17-51 
6.2 Hercules Registers 17-51 
6.3 Enable Mode Register Port 3B8H 17-51 
6.4 Hercules Compatibility Register, Write Only Porc 7 3BFH 17-52 
6.5 Color CGA Operation Register, Write Only Port = 3D8H 17-52 
6.6 CGA Color Select Register, Write Only Port = 3D9H 17-53 
6.7 CRT Status Register, MDA Operation, Read Only Port = 3BAH 17-54 
6.8 CRT Status Register, CGA Operation, Read Only Port = 3DAH 17-54 
6.9 AT&T/M24 Register, Write Only Port = 3DEH 17-55 

7.0 PR REGISTERS 17-56 
7.1. Address Offset Acacias PROA And PROB ; 17-58 
7.2 PR1- Memory Size, Read/Write Port = 3CFH, Index = OBH 17-59 
7.3 PR2 - Video Select Register, Read/Write Port = 3CFH, Index = OCH . 17-62 
7.4_PR3 - CRT Lock Control Register, Read/Write Port = 3CFH, Index = ODH 17-63 

7.4.1 CRT Controller Register Locking 17-64 
7.5 PR4- Video Control Register, Read/Write Port = 3CFH, indeve OEH 17-65 
7.6 PR5- General Purpose Status Bits, Read/Write Port = 3CFH, 

Index = OFH ; ds A SE aS. te Oh a es SE 17-66 
7.7 PR10 - Unlock PR1A, PR(17: 11) Read/Write Port = 375H, Index = 29H 17-66 
7.8 PR11- EGA Switches, Read/Write Port = 375H, Index = 2AH 17-67 
7.9  PR12 - Scratch Pad, Read/Write Port = 375H, Index = 2BH 17-68 
7.10 PR13 - Interlace H/2 Start, Read/Write Port = 375H, Index = 2CH 17-68 
7.11. PR14 - Interlace H/2 End, Read/Write Port = 3?75H, Index = 2DH 17-68 
7.12 PR15 - Miscellaneous Control 1, Read/Write Port = 375H, Index = 2EH 17-69 
7.13 PR16 - Miscellaneous Control 2, Read/Write Port = 3?75H, Index = 2FH 17-71 
7.14 PR17 - Miscellaneous Control 3, Read/Write Port = 375H, Index = 30H 17-72 

W3/92 17-ili 


WD9I0C31A 








Section Title Page 
7.15 PR18- CRTC Vertical Timing Overflow, Read/Write Port = 375H, 
Index = 3EH 17-72 
7.16 PR19 - Video Signature naaivzer Control Read/Write Port = 325H, 
Index = 3FH 17-73 
7.17 PR1A- Shadow Raciior Control, Read/Write Port = 325H, ndeie 3DH 17-73 
7.18 PR20 - Unlock Sequencer Extended Registers, Read/Write Port 3C5H, 
Index = 6H, (Reset State = Locked) 5 ed 17-73 
7.19 PR21 - Display Configuration Status And Scratch Pad Bits Register 
Bits 7:4 Read/Write Bits 3:0, Read Only Port 3C5H, Index = 7H 17-74 
7.20 PR22 - Scratch Pad Register, Read/Write Port = 3C5H, Index = 8H 17-74 
7.21  PR23 - Scratch Pad Register, Read/Write Port = 3C5H, Index = 9H 17-74 
7.22 PR830 - Memory Interface, Write Buffer And FIFO Control Register, 
Read/Write Port = 3C5H, Index 10H , 17-74 
7.23 PR31 - System Interface Control, Read/Write Port = 3C5H, index = 11 H, 
Reset State = 00 _ bate see gf eS 17-75 
7.24 PR82 - Miscellaneous Canitrol 4, ReadMrite Port = 3C5H, 
Index = 12H, Reset State = 00 on 17-76 
7.25 PR33 - DRAM Timing And Zero Wait State Control Register, 
Read/Write Port = 3C5H, Index = 13H 17-77 
7.26 PR34 - Video Memory pee fon Read/Write Port = 3C5H, 
Index = 14H id oe 17-78 
7.27 PR35 - Reserved, Read/Write Port = 3C5H, Index = 15H 17-78 
8.0 INTERNAL I/O PORTS ; 17-79 
8.1. AT Mode Setup, Enable, Write Only Port A6ESH 
(Also At Port 56E8H, 66E8H, 76E8H) 17-79 
8.2 Setup Mode Video Enable (AT And Micro Channel Modes) 
Read/Write Port = 102H (XXXX XXXX XXXX X010B) 17-79 
9.0 CONFIGURATION REGISTER BITS CNF(18:0) 17-80 
10.0 HARDWARE CURSOR 17-83 
10.1 Cursor Control Register, Index 0 17-83 
10.2 Cursor Pattern Address : 17-83 
10.2.1 Cursor Pattern Address ow index 17-84 
10.2.2 Cursor Pattern Address High, Index 2 17-84 
10.3 Cursor Origin, Index 5 17-84 
10.4 Cursor Display Position 17-84 
10.4.1. Cursor Display Position x, Index 6 17-84 
10.4.2 Cursor Display Position Y, Index 7 17-84 
10.5 Cursor Color Registers : 17-85 
10.5.1. Cursor Primary Color, hides 3 17-85 
10.5.2 Cursor Secondary Color, Index 4 17-85 
10.5.3 Cursor Auxiliary Color, Index 8 17-85 
10.6 Cursor Register Updates 17-85 
17-iv 9/3/92 


WD90C31A 








Section Title Page 
10.6.1. Cursor Address Mapping 17-85 
10.6.2 Two-Bit Cursor Pattern Format 17-87 

10.6.2.1. Cursor Pattern - 2-Bit, 64 x 64 cursors. 17-87 

10.6.2.2 Cursor Pattern - 2-Bit, 32 x 32 Cursors 17-87 

10.6.3 Loading The Cursor Pattern 17-87 

10.6.4 Cursor Color Modes ; ; 17-88 
10.6.5 Compatibility Differences peween Hardware And 

Software Cursor a ee ee ee 17-88 

10.6.6 Cursor Plane Protection 17-88 

11.0 HARDWARE BITBLT 17-89 

11.1. Control And Status 17-89 

11.2 Source And Destination 17-91 

11.2.1. BITBLT Source Low, Index 2 2 17-92 

11.2.2 BITBLT Source High, Index 3 17-92 

11.2.3. BITBLT Destination Low, Index 4 17-92 

11.2.4 BITBLT Destination High, Index 5 17-92 

11.3 Address Mapping ane 17-92 

11.3.1 Monochrome And Planar Modes 17-92 

11.3.2 Packed Modes 17-92 

11.4 Dimensions And Row Pitch a 17-93 

11.4.1. BITBLT Dimension X, Index 6 17-93 

11.4.2 BITBLT Dimension Y, Index 7 17-93 

11.4.3. BITBLT Row Pitch, Index 8 17-93 

11.5 Foreground And Background Colors 17-94 

11.6 Map And Plane Mask 17-94 

11.7 Raster Operations 17-95 

11.8 Patterns heh A eR: a Gy eB oes cee Se oe es 17-95 

11.8.1. BITBLT Pattern Storage - Monochrome And Planar Modes 17-96 

11.8.2 BITBLT Pattern Storage - Packed Modes 17-96 

11.9 Monochrome To Color Expansion 17-96 

11.10 Extracting Monochrome Data 17-97 

11.11 Color Transparency 17-97 

11.11.1. BITBLT nidnessigng: Color Rees C 17-97 

11.11.2 BITBLT Transparency Mask, Index D 17-97 

11.12 Filled Rectangles 17-98 

11.13 System Memory To Display Misinety Opeiations 17-98 

11.14 Display Memory To System Memory Operations 17-98 

11.15 System Memory To Display Memory Transfers With Color eeparision 17-99 

12.0 EXTENDED REGISTER ACCESS 17-100 

12.1 Accessing Indexed Registers 17-100 

17-v 


Ya 9/3/92 


WD90C31A 








Section Title Page 
12.2 Index Control Register Port 23COH/23C1H , 17-100 

12.3 Interrupt Status Register, System Control Registers Block - dex 0 17-101 

12.3.1 Global Interrupt Map 17-101 

13.0 APPLICATION AND PROGRAMMING NOTES 17-102 
13.1 Use Of The Hardware Cursor In 16-bit Per Color Mode. 17-102 

13.2 BITBLT In VGA Modes 4, 5, And 6 17-102 

13.3 BITBLT Operations In Text Mode 17-102 

13.4 Use Of BITBLT In 16-Bit Per Color Mode 17-103 

13.5 Use Of BITBLT For Arbitrary Sized Patterns 17-103 

13.6 Patterns Built On-Screen 17-103 

13.7 Use Of Patterns In Text Mode 17-104 

13.8 Support For KANJI] Characters . 17-104 

13.9 VCLK And MCLK Ratio For High Resolution higdes: 17-105 

14.0 WD90C31A INTERFACES ; 17-106 
14.1. 8-BIT PC AT Interface With 8-Bit BIOS 17-107 

14.2 16-BIT PC AT Interface With 8-Bit BIOS 17-108 

14.3 16-BIT PC AT Interface With 16-Bit BIOS 17-109 

14.4 16-BIT Micro Channel 17-110 

14.5 WD90C31A Interface For 286 Or 386 Based Systems 17-111 

14.6 WD90C31A With RAMDAC Interface 17-114 

14.7. WD90C31A And TTL Monitor Connections 17-115 

14.8 Clock Interface 17-116 

15.0 SHADOW REGISTER IMPLEMENTATION 17-117 
16.0 SIGNATURE ANALYZER 17-118 
16.1. Description 17-118 

16.2 Operation 17-118 

17.0 /O MAPPING 17-120 
17.1. Introduction 17-120 

17.2 Test Mode 17-120 

17.3. Pin Groupings 17-120 

18.0 DC ELECTRICAL SPECIFICATIONS 17-124 
18.1. Maximum Ratings . 17-124 

18.2 Standard Test Conditions 17-124 

18.3. DC Characteristics 17-124 

19.0 AC TIMING CHARACTERISTICS 17-125 
20.0 PACKAGE DIMENSIONS 17-137 
17-vi 9/3/92 Ga 


WD90C3I1A 








LIST OF TABLES 
Table Title Page 
4-1 WD90C31A 132-PIN PQFP ASSIGNMENTS 17-8 
4-2 WD90C031A 144-PIN MQFP ASSIGNMENTS 17-9 
4-3 SIGNAL DESCRIPTION 17-10 
5-1 VGA REGISTERS SUMMARY 17-21 
5-2 EGA REGISTERS SUMMARY 17-22 
5-3 CRT CONTROLLER REGISTERS 17-29 
5-4 GRAPHICS CONTROLLER REGISTERS 17-39 
5-5 WRITE MODES , 17-43 
5-6 ATTRIBUTE CONTROLLER REGISTERS 17-45 
5-7 LEFT SHIFT PIXEL VALUE 17-48 
5-8 VIDEO RAMDAC PORTS 17-49 
6-1 COMPATIBILITY REGISTERS SUMMARY | 17-50 
7-1 PR REGISTERS SUMMARY ; 17-57 
7-2 IBM COMPATIBLE MEMORY ORGANIZATION 17-59 
7-3 WD90C31A MEMORY ORGANIZATION - 256 KBYTES 17-60 
7-4 WD90C31A MEMORY ORGANIZATION - 512 KBYTES 17-60 
7-5 WD90C31A MEMORY ORGANIZATION - 1 MBYTES 17-61 
10-1 CURSOR REGISTERS 17-83 
10-2 PLANAR MODES 17-86 
10-3 PACKED MODES 17-86 
10-4 TEXT MODES ; 17-86 
10-5 CURSOR COLOR MODES» 17-88 
11-1 BITBLT REGISTERS INDEX 17-89 
11-2 BITBLT TRUTH TABLE 17-95 
11-3 RASTER OPERATION CODE , 17-95 
13-1 VCLK AND MCLK FOR HIGH RESOLUTION MODES 17-105 
15-1 SHADOW REGISTER IMPLEMENTATION 17-117 
16-1 CONTROL REGISTER PR19 17-118 
17-1 WD90C31A PIN SCAN MAP FOR 132- PIN PACKAGE 17-121 
18-1 DC CHARACTERISTICS 17-124 
19-1 AC TIMING CHARACTERISTICS 17-125 
9/3/92 17-vii 


WD90C31A 








LIST OF FIGURES 
Figure Title Page 
2-1 SYSTEM BLOCK DIAGRAM 17-3 
3-1 WD90C31A BLOCK DIAGRAM 17-6 
4-1 132-PIN PQFP PACKAGE 17-7 
4-2 144-PIN MQFP PACKAGE 17-7 
14-1 WD90C31A INTERFACES 17-106 
14-2 8-BIT PC AT INTERFACE WITH 8-BIT BIOS 17-107 
14-3 16-BIT PC AT INTERFACE WITH 8-BIT BIOS 17-108 
14-4 16-BIT PC AT INTERFACE WITH 16-BIT BIOS 17-109 
14-5 16-BIT MICRO CHANNEL INTERFACE 17-110 
14-6 WD90C31A INTERFACE FOR 286 OR 386-BASED SYSTEMS 17-111 
14-7 TWO, FOUR OR EIGHT 64K BY 16 DRAM INTERFACE 17-112 
14-8 FOUR OR EIGHT 256K BY 4 DRAM INTERFACE 17-113 
14-9 WD90C31A WITH RAMDAC INTERFACE 17-114 
14-10 WD90C31A AND TTL MONITOR CONNECTIONS 17-115 
14-11 CLOCK INTERFACE 17-116 
16-1 LINEAR FEEDBACK SHIFT REGISTER | 17-118 
17-1 TEST MODE CIRCUIT 17-120 
17-2 WD90C31A PIN SCAN MAP FOR A 132- PIN PACKAGE 17-123 
19-1 RESET TIMING ; 17-131 
19-2 CLOCK AND VIDEO TIMING 17-131 
19-3 AT MODE BUS TIMING ; 17-132 
19-4 MICRO CHANNEL MODE BUS TIMING 17-133 
19-5 DRAM TIMING 17-134 
19-6 DRAM TIMING ADJUSTMENT 17-135 
19-7 256K BY 4 DRAM TIMING 17-136 
19-8 64K BY 16 DRAM TIMING 17-136 
20-1 132-PIN PQFP PACKAGE 17-137 
20-2 144-PIN MQFP PACKAGE 17-138 
ADDITIONAL REFERENCES 
IBM Personal Computer Hardware User Guide (IBM # 6322510) 
IBM Personal Computer XT Hardware User Guide (IBM # 6322511) 
IBM Personal System 2 Model 30 Hardware User Guide (IBM # 6383x2230) 
IBM Personal Computer AT Technical Reference Manual (IBM # 6280070) 
IBM Personal System 2 Model 30 Technical Reference Manual (IBM # 63x2201) 
IBM PC Options And Adapters Technical Reference Manual (IBM # 6322509) 
IBM Personal System 2 BIOS Reference Manual (IBM # 68x2260) 
17-viil 9/3/92 


INTRODUCTION WD9I0C3IA 





1.0 INTRODUCTION 


The WD90C31A VGA Controller is a 0.9 micron 
CMOS VLSI device that allows the design of a VGA 


graphics subsystem to interface with either the AT 100% hardware compatible with IBM’s VGA 
bus or the IBM Micro Channel bus, while maintain- and EGA with hidden register support. 

ing backward compatibility with previous video P , 

standards such as MDA, EGA, CGA, Hercules and oe epee eae i at and 

AT&T 6300. A major advantage of the WD90C31A p 
is that designs implementing this graphics controller = * Supports all IBM VGA modes with two 64K by 
are able to run applications requiring VGA hardware 16 DRAMs or only one 256K by 16 DRAM. ® 
and BIOS compatibility and also EGA register level 
compatibility on analog, TTL, or multifrequency With more DRAMS installed it can support 256 
monitors, in interlace or non-interlace mode. The colors at the following resolutions: 640 by 400, 
WD90C31A supports high resolution graphics with 640 by 480, 800 by 600 and 1024 by 768. @ 
1024 by 768 dot resolution and 256 colors. The 
WD90C31A also supports 132-column text mode 
and 6-16 pixel fonts. 


Pin compatible with the WD90C30. 





Supports 132-column text. 


Write buffer for zero wait state CPU write 


This document supplies a functional overview, performance. 


signal pin details, a block diagram, internal 8-bit or 16-bit data bus for I/O and memory. 


register descriptions, AC/DC characteristics, True 16-bit CPU to video memory transfer for 
timing diagrams, VLSI package information and all modes. 


associated references. 


Provides 16-bit or 32-bit memory interface with 
fast page operations. 


1.1. FEATURES Up to 80 MHz maximum video clock rate. © 


* A full-function VGA controller optimized for * Up to 50 MHz maximum memory clock rate. © 
windows. 


Up to four simultaneous displayable fonts. 


Hardware Cursor. 
- Up to 64 by 64 pixels. 
- Inversion and transparency. 


6-16 pixel-wide fonts. 


A maximum of 16 fonts can be loaded. 


Provides adapter video BIOS ROM decoding. 


- Two color and three color modes. 


eG Eleven-bit vertical counter to support scan 
Hardware BITBLT. resolution of up to 2048 scan lines. 


- Raster operations. Special double scanning and underline. 


- Transparency. * Special display enable or blanking output 
- Color expansion for text support. signal. 
- Rectangular and linear addressing. * Special border disable. 
- Filled rectangles. ° Lockable palette, RAMDAC and overscan 
- Transfers to and from the Host. registers. 
¢ Provides single chip video graphics solution for ¢ Special CRTC shadow registers for support of 
IBM AT and PS/2 compatible systems. non-standard monitors. 
¢ Supports two, four or eight 64K by 16 DRAMs; * Special register locking for flat panel 
four or eight 256K by 4 DRAMs; and one or applications. 


two 256K by 16 DRAMs. ® 
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Supports 16-bit I/O register transfer to 
index/data register pairs. 


Adjustable internal FIFO and fast page 
memory interface. 


Low power 0.9 micron CMOS technology. 


132-pin PQFP (Plastic Quad Flat Package) or 
144-pin MQFP (Metric Quad Flat Package). 


Integrated Feature connector interface and 
external RAMDAC support. 


Integrated bus interface for AT and Micro 
Channel with minimum external component 
support. 


Programmable memory mapping register to 
map WD90C31A into any CPU memory 
address space. 


Eight-bit CPU address offset register to support 
1 Mbyte memory segmentation. | 


@ 256 by 16 DRAMs must have nine address 


lines, one CAS line and two WE lines. 


@ Refer to Section 13.9 for high resolution mode 
considerations. 


1.2 GENERAL DESCRIPTION 


This document describes the WD90C31A VGA 
controller specifically designed for the Microsoft 
Windows marketplace. The WD90C31A incor- 
porates numerous advanced features that Win- 
dows drivers may take advantage of for increased 
performance. 


Although the WD90C31A replaces the WD90C31 
it is identical to the WD90C31 in pinout and 
functionality. The WD90C31A provides substantial 
performance improvement over the WD90C31 
when used with the Western Digital BIOS version 
521 and Western Digital utilities version 4.2 or 
newer. 


The WD90C31A is fully compatible with the 
WD90C30, making it possible to utilize the addi- 
tional features of the WD90C31A by upgrading 
only the BIOS and software drivers. 


INTRODUCTION 


1.2.1 Hardware Cursor 


The WD90C31A supports a hardware cursor with 
a user-defined pattern of up to 64 by 64 pixels at 
two bits per pixel. The cursor pattern is stored in 
off-screen display memory. A programmable 
origin is provided and cursors may be displayed 
with any two or three desired colors. 


1.2.2 Hardware BITBLT 


The WD90C31A provides hardware accelerated 
Bit Block Transfers (BITBLT) of data between 
regions of display memory, or between display 
memory and a fixed I/O port. Display memory 
regions may be rectangular or linear. 


The BITBLT hardware supports text modes as 
well as monochrome, 4-bit (16-color) and 8-bit 
(256 color) modes. 


A full complement of raster operations and 
transparencies are available, as well as 8 by 8 
color patterns. Color expansion, useful for ac- 
celerating text modes is supported. Plane mask- 
ing is also Supported. 
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2.0 WD90C31A ARCHITECTURE 


The WD90C31A contains six major internal 
modules, the CRT Controller, the Sequencer, the 
Graphics Controller, Hardware Cursor Controller, 
BITBLT Controller and the Attribute Controller. 
The WD90C31A also has four major interfaces: 
the CPU and BIOS ROM interface, the DRAM 
Display Buffer interface, the Video and RAMDAC 
interface and the Clock interface. 


An internal four-level write buffer is used to 
achieve fast memory write. A zero wait state may 
be achieved with a 32-bit video memory interface 
for most memory write operations. 


An internal FIFO is used to achieve the video dis- 
play bandwidth necessary to interleave CPU ac- 
cesses and display refresh cycles. 


The CRT Controller module maintains screen 
refresh functions for the various display modes 
defined by the BIOS ROM resident firmware. The 
CRT Controller module also generates a horizon- 
tal sync (HSYNC), vertical sync (VSYNC) and 
blanking signal for the display monitor. 


The Sequencer functions as a timing generator for 
the display memory cycles. It provides the charac- 


WD90C31A 


AT/MCA 
INTERFACE 


‘CURSOR | 
| CNTRL 1 


EXT/OSC 


CLOCK ! 


WD90C31A 


ter clock in the alphanumeric mode and the dot 
clock in the graphics mode. The sequencer ar- 
bitrates between video display refresh, memory 
refresh and CPU access of the video memory. 
The sequencer also provides write buffer control. 


The Graphics Controller manipulates the data flow 
between the CPU and the video memory for both 
CPU write and CPU read cycles. 


The Attribute Controller serializes the video 
memory data into video data stream according to 
different display formats. It controls blinking, un- 
derlining, cursor, pixel panning, reverse video and 
background or foreground color in all display 
modes. 


The Hardware Cursor Controller reads in each 
line of the cursor pattern during the horizontal 
retrace immediately preceding the scan line on 
which that line of the cursor pattern is to be dis- 
played. It then merges the cursor pattern into the 
video stream for the scan line. 


The BITBLT Controller generates addresses and 
data for BITBLT operations, including pattern, rec- 
tangle and system-to-display memory operation. 


VIDEO 
MEMORY 
256 KB - 1 MB 


ANALOG/DIGITAL 
COLOR/MONO MONITOR 


FIXED OR 
VARIABLE 
SCAN 


RAMDAC 





FIGURE 2-1. SYSTEM BLOCK DIAGRAM 
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3.0 WD90C31A INTERFACES 
3.1. CPU AND BIOS ROM INTERFACE 


The WD90C31A is designed to operate in both 
the AT Bus and the PS/2 Micro Channel Bus ar- 
chitecture configurations. The selection of the 
mode depends on the setting of the Configuration 
Register bit CNF(2), which is determined upon 
power-up/reset and is described in Section 9, 
WD90C31A Configuration Register Bits CNF(18:0). 


Whether configured for AT or Micro Channel 
operation, the WD90C31A operates functionally in 
a manner conducive to AT or Micro Channel inter- 
facing. The signal pins, memory maps and I/O 
ports all operate to optimize this interface with 
minimal external circuitry. 


The WD90C31A provides all the signals and 
decodes all the necessary memory and |/O ad- 
dresses to interface with the AT bus or the Micro 
Channel bus in 8-bit or 16-bit data path modes. 
WD90C31A also provides the necessary decod- 
ing of the adapter video BIOS ROM. Using the 
provided signals, it is possible to implement 
designs which operate in 8-bit or 16-bit mode and 
control an 8-bit or 16-bit BIOS ROM. 


The I/O data path can be programmed to be 
either 16-bit or 8-bit. The CPU to display buffer 
data path can also be eight or sixteen bits wide 
for all modes. ROM16, 1|OCS16, and MEMCS16 
signals are generated by the WD90C31A to indi- 
cate a 16-bit operation. 


The WD90C31A has a display memory write buff- 
er which holds the CPU write data until it can be 
transferred to the display memory, allowing the 
CPU to continue. This feature greatly reduces CPU 
wait states while writing to the video memory. 








The WD90C31A provides the necessary wait 
states for CPU accesses to the video memory if 
necessary. Wait states for I/O accesses and BIOS 
ROM accesses are not generated. 


Special I/O ports such as 46E8H for the AT (or 
03C3H for Micro Channel) for setup and 102H for 
VGA enable, have been implemented internally in 
the WD90C31A. 


WD90C31A INTERFACES 


3.2 DRAM INTERFACE 


The WD90C31A has a very flexible DRAM inter- 
face. It can work with two, four, or eight 64K by 16 
DRAMs with a 32-bit memory interface. It can also 
work with four 256 Kbyte by 4 DRAMs and one 
256 Kbyte by 16 DRAM with a 16-bit memory 
interface. Other possible configurations are eight 
256 Kbyte by 4 DRAMS or two 256 Kbyte by 16 
DRAMS with a 32-bit memory interface. In all 
cases the WD90C31A uses the DRAM fast page 
mode to optimize performance. 


The WD90C31A can support all standard IBM 
VGA modes with only two 64K by 16 DRAMs. 
Because it uses a 32-bit memory interface and 
has internal write buffer, the WD90C31A can up- 
date the video memory without inserting wait 
states to the AT bus for most standard IBM VGA 
modes. 


When_ additional DRAMs are_installed the 
WD90C31A is capable of supporting high resolu- 
tion color video modes (1024 by 768 with 256 
colors, non-interlaced at 72 Hz vertical refresh 
rate). 


The WD90C31A is designed to support 60 ns, 70 
ns, 80 ns and 100 ns DRAMs with the dedicated 
MCLOCK which can operate from 32 MHz to 50 
MHz maximum. 


The WD90C31A generates fast page DRAM 
timing for all BITBLT, cursor and CPU accesses, 
graphics display and text display. A choice of 
page mode and non-page mode operation is 
provided to access fonts in text modes. 


The WD90C31A also generates CAS before RAS 
DRAM refresh for the display memory. 


3.3 VIDEO INTERFACE 


The WD90C31A is optimized to connect to an 
analog CRT monitor through a RAMDAC but it 
may also be used to drive other types of displays, 
such as TTL monitors. In interfacing to an analog 
monitor through an external RAMDAC, the 
WD90C31A provides all the necessary signals to 
interface to the video RAMDAC. 
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The video interface for a CRT is very dependent 
on the CRT requirements and the resolution and 
depth (bits/pixels) of the image desired. New 
monitors such as multifrequency monitors, are less 
stringent because of the many sync frequencies 
available. The WD90C31A can be programmed to 
directly generate all the CRT signals for up to 
eight bits/pixel (256 color) displays. 


The Micro Channel Auxiliary Video Connector and 
the AT Feature Connector can be connected 
directly to the WD90C31A. The WD90C31A also 
provides an input for a monitor type detection in- 
terface as done on the IBM VGA using com- 
parators. 


3.4 CLOCK INTERFACE 


The WD90C31A has four clock input signals, 
Memory Clock, MCLK, which drives the DRAM 
and bus interface timing, and the three Video 
Clocks, VCLKO, VCLK1, and VCLK2, which drive 
the video timing. VCLK1 and VCLK2 can also be 
programmed as outputs to provide the option to 
externally control a multiplexer that supplies the 
video clock. MCLK can also be selected as a 
memory clock or video clock. 


WD90C31A 


3.5 WD90C31A POWER-UP CONFIGURA- 
TION 


The WD90C31A uses the memory data pins to 
configure an internal configuration register upon 
power-up-reset. CNF(2) determines whether the 
WD90C31A will operate in AT or Micro Channel 
Architecture (MCA) implementation. Other CNF 
bits configured by the WD90C31A at power-up- 
reset are used as status bits or for clock source 
control. For more information on WD90C31A 
power-up configuration, refer to Section 9, Con- 
figuration Bits. 
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4.0 SIGNAL DESCRIPTION 


Table 4-1 provides a list of pin assignments forthe nals controlled by the WD90C31A, and both the 


132-pin PQFP package. Table 4-2 provides alist PQFP and MQFP pins are identified. The 
of pin assignments for the 144-pin MQFP pack- © WD90C31A mnemonics are used. 17 
age. Table 4-3 provides a description of the sig- 


PIN #1 ID 


PIN #1 ID 





FIGURE 4-2. 144-PIN MQFP PACKAGE 
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PIN NUMBER 
PQFP - MQFP 


MNEMONIC | I/O DESCRIPTION 


POWER ON 


RESET 

This signal resets the WD90C31A. To initialize the 
WD90C31A during reset, MCLK and VCLKO must be con- 
nected to the WD90C31A. Western Digital configuration 
bits are initialized at power-up reset, based on the logic 
level on the MD(15:0) bus, as determined by pull-up/pull- 
down resistors. The reset pulse width should be at least 
10 MCLK clock periods. 


CLOCK SELECTION 


MEMORY CLOCK 

This clock signal determines the VGA DRAM timing as 
well as system interface control timing. MCLK should be a 
minimum 37.5 MHz for 80 ns DRAMS. 


VIDEO CLOCK 0 

This input is the video display clock for alphanumeric and 
graphics display modes. Typically, VCLK is 25.175 MHz to 
display 640 pixels per horizontal display line. VCLKO is 
selected as clock when VCLK1 and VCLK2 are used as 
inputs and both Miscellaneous Output Register bits 2 and 
3 set to 0. 


VIDEO CLOCK 1 

VCLK1 can be a second video display clock input or an 
output to an external clock selection module. The direc- 
tion is determined at Reset by a pull-up/down resistor on 
MD3. A VCLK1 input frequency of 28.322 MHz is used to 
display 720 pixels per horizontal line. As an output, 
VCLK1 is an active low pulse during I/O writes to port 
3C2H, or reflects the contents of 03C2H, Miscellaneous 
Register Bit 2. Refer to the Configuration Register and 
PR15 Register, Bit 5 description. 


VIDEO CLOCK 2 

VCLKk2 is a third video display clock input or an output to 
external clock selection module. Pin direction is 
programmed simultaneously with that of VCLK1. VCLK2 
performs as a user-defined external clock input, an output 
reflecting the state of Bit PR2(1) or represents the state of 
03C2H, Miscellaneous Register, Bit 3, when CNF(3) is set 
to 1. See the Configuration Register and PR15 Register, 
Bit 5 description. 





TABLE 4-3. SIGNAL DESCRIPTION 
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SIGNAL DESCRIPTION 
PIN NUMBER 
Parp-marp | MNEMONIC 





69 - 57 

68 - 56 

66 - 383 

65 - 52 

64 - 51 

63 - 50 

62 - 49 

89 - 79 

73 - ~~ 61 

90 - 80 DA15 

91 - 81 DA14 

92 - 82 DA13 

93 - 83 DA12 

94 - 84 DA11 

95 - 85 DA10 

96 - 86 DAQ 

97 - 87 DA8 
101. - 92 DA7 
102 - = 93 DA6 
103 - 94 DA5 
104 - 9 DA4 
105 - 96 DAS 
106 - 9Q9/ DA2 
107. - 98 DA1 
108 - 99 DAO 

82 - 70 lIOCHRDY 








HOST INTERFACE 





WD9I0C31A 


DESCRIPTION 





ADDRESS BUS (A23 - A17) 
In Micro Channel mode, A(23:17) should be connected to 
address bus SA(23:17). 


In AT mode, A(23:17) should be connected to LA(23:17) of 
the AT address bus. 


ADDRESS BUS (A16) 
Bit SA16 of CPU address bus. 


ADDRESS LATCH ENABLE 
In AT mode, A(23:17) are latched internally at the falling 
edge of the ALE. 


In Micro Channel mode, ALE is not used and should be 
connected to VSS. 


DATA/ADDRESS BUS 
This is the multiplexed CPU data and address bus. 


EABUF = 0: Enables the external address buffer. 


EDBUFL = 0 or EDBUFH = 0: Enables the external 
bidirectional data buffers. 


DIR controls the data flow for the data buffer. 


lO CHANNEL READY 

When low, IOCHRDY indicates to the system processor 
that the Video Controller is not able to immediately com- 
plete the requested memory or I/O access, and causes the 
system processor to wait until IOCHRDY is de-asserted, | 
indicating completion of the transfer. 


This signal is not generated on I/O cycles and accesses to 
the BIOS ROM. 


TABLE 4-3. SIGNAL DESCRIPTION (Continued) 
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WD9I0C3IA SIGNAL DESCRIPTION 


PIN NUMBER 
PQFP - MQFP MNEMONIC | W/O DESCRIPTION 


HOST INTERFACE (Cont.) 


74 - 62 IRQ/(IRQ) O INTERRUPT REQUEST 
This programmable processor interrupt request is enabled 
via Bit 5 in the Vertical Retrace End register. When the 
end of Vertical Display occurs, this signal is active, causing 
the interrupt. It stays active until cleared by CRTC11 Bit 4. 


An AT system uses IRQ as an active high signal. Although 
an AT system does not usually use IRQ it may be con- 
nected if desired. 


The Micro Channel mode uses IRQ as an active low to 
generate interrupts. 


71 - 59 MEMCS16/ O MEMORY CHIP SELECT 16 BITS 
(CDDS16) In AT mode, MEMCS16 is used to inform the host that the 
WD90C31A is capable of performing the requested 16-bit 
video memory data transfer. 


In Micro Channel mode, CDDS16 is used to indicate 16-bit 
video memory or I/O access. 


85 - 75 ElO/ | ENABLE I/O 
(8C3B0) In AT mode, EIO is used to enable I/O address decoding 
and is connected directly to the system bus signal AEN 

(address enable). 


In Micro Channel mode, EIO is enabled by I/O port 3C3 bit 
0 = 1, and is used to enable video subsystem memory and 
I/O address decoding. 





87 - 77 EBROM O ENABLE BIOS ROM 
This is an active low signal to enable BIOS ROM (CO000H 
- C7FFFH) if enabled by PR1(0). A write to WD90C31A 
internal I/O port address 46E8H causes this signal to be 
used as a write strobe for an external register used in 
BIOS ROM page mapping. 


113 - 104 HTL O ENABLE HIGH-TO-LOW 
(for 16-bit BIOS) If only an eight-bit CPU interface is used, 
this output enables a data buffer to allow reading of the 
upper byte of ROM data on the lower data bus when two 
ROMs (16-bit) are supported. 


TABLE 4-3. SIGNAL DESCRIPTIONS (Continued) 


NOTE: 
(__) Signals enclosed in parentheses are Micro Channel only. 
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SIGNAL DESCRIPTION WD9I0C31A 


PIN NUMBER 


BORE CMOER DESCRIPTION 


MNEMONIC | I/O 


HOST INTERFACE (Cont.) 





72 


81 


78 


79 


76 


NOTE: 


60 


69 


66 


67 


64 


EMEM | 


58) 
al 
m 


OWS 


MRD/(M/0) 


MWR/(S0) 


ENABLE MEMORY 
When asserted, EMEM enables memory decoding. It is 
normally connected to the Refresh signal. 


BYTE HIGH ENABLE: oe 
BHE should be connected to BHE of the AT or Micro 
Channel bus. 
BHE, SAO = 00 - Word transfer 
= 01 - High byte transfer 
= 10 - Low byte transfer 
= 11 - Illegal 


ZERO WAIT STATE 

OWS is asserted to generate a zero wait state to the AT 
bus. OWS is controlled by the PR33 register, bits 7 and 6. 
See section 7.25 for programming. 





MEMORY READ 
In AT mode, this signal is called MRD and is an active low 
memory read strobe. 


In Micro Channel mode, the signal is called M/IO. It distin- 
guishes between memory and I/O cycles. When (M/IO) is 
high, a memory cycle is in process. A low on (M/IO) 
shows that an I/O cycle is in process. 


MEMORY WRITE 
In AT mode MWR is the memory write strobe. 


In Micro Channel mode, SO is the channel status signal 
and indicates the start and type of a channel cycle. Along 
with S1, M/IO and CMD signals, it is decoded to interpret 
/(O and memory commands. 





VOREAD 
In AT mode IOR is the |/O read strobe. 


In Micro Channel mode, $1 is the channel status signal 
that indicates the start and type of a channel cycle. 


TABLE 4-3. SIGNAL DESCRIPTIONS (Continued) 


(_) Signals enclosed in parentheses are Micro Channel only. 
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WD9I0C31A SIGNAL DESCRIPTION 


PIN NUMBER 
POFP - MOFP MNEMONIC | I/O DESCRIPTION 


HOST INTERFACE (Cont.) 


lOW/(CMD) | 1/O WRITE 
In AT mode, IOW strobe signals an I/O write. 


In Micro Channel mode CMD _ is the bus data strobe. 
Address bus validity is signaled by CMD going low while 
the rising edge of CMD indicates the end of a Micro 
Channel bus cycle. 


lOCS16 1/O CHIP SELECT 16 BITS 

(CDSETUP) In AT mode, 1OCS16 is an output, and is used to inform 
the host that the WD90C31A is capable of performing the 
requested 16-bit I/O accesses. 


In Micro Channel mode, this signal is an input driven by 
the host to individually select channel connector slots 
during system configuration. 


DIRECTION CONTROL 

DIR is the Direction Control for external bus buffers in 
both AT and Micro Channel implementation. The default 
State is low until a read cycle occurs. The WD90C31A 
then drives DIR high to change the direction of the data 
buffers. 


EDBUFH ENABLE DATA BUFFER HIGH 
EDBUFH may be used to enable an external data buffer 
for data bits D15 through D8. 


ENABLE DATA BUFFER LOW 
EDBUFL may be used to enable an external data buffer 
for data bits D7 through DO. 


ENABLE ADDRESS BUFFER 
EABUF may be used to enable an external address buffer. 





TABLE 4-3. SIGNAL DESCRIPTION (Continued) 


NOTE: 
(_ ) Signals enclosed in parentheses are Micro Channel only. 
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SIGNAL DESCRIPTION 


PIN NUMBER 
PQFP - MQFP 


86 


41 


39 


28 


2/ 





76 


26 


24 


12 


132 


MNEMONIC | 1/O 


ROM16/ 
(CSFB)/ 


EXBLANK 


CAS 


RAS 


RAS3 


RAS4 


WD90C31A 


DESCRIPTION 


HOST INTERFACE (Cont.) 








BIOS ROM SELECT 16 BITS 

In AT Mode, ROM16 is an output and decodes the ROM 
address LA(23:17) for space OCO000 - ODFFFF. It may be 
combined with SA16 and SA15 externally to control 
MEMCS16 for the address space C0000 - C7FFF. If 
CNF(17) is set to 0 at power up reset, the ROM16 address 
decoding is disabled. ROM{16 then reflects the status of 
PR1 bit 1. 








CARD SELECT FEEDBACK 

In Micro Channel mode, CSFB is an output and is used as 
Card Selected Feedback to provide positive acknow- 
ledgement of its presence at the specified host’s addresses. 


EXTERNAL BLANK 
In AT or Micro Channel Mode, EXBLANK becomes an input 
lf CNF(18) is set to zero (MD18 = 0 at power-up reset). 


EXBLANK = 1: Enables BLANK, VSYNC and HSYNC 
outputs. 

EXBLANK=0: Tristate BLANK, VSYNC and HSYNC 
outputs. 


DISPLAY MEMORY INTERFACE 


O 


COLUMN ADDRESS STROBE 
CAS is the Column Address Strobe for two, four and eight 
DRAM configurations. 


ROW ADDRESS STROBE 

RAS is the Row Address Strobe for the 256K by 4, or 256K 
by 16 DRAM interface. If 64K by 16 DRAMS are used, 
RAS is the strobe for the first 256 Kbyte memory bank. For 
RAS2 see pin 61 in Video Memory Address section. 


ROW ADDRESS STROBE 3 
RAS3 is used only if eight 64K by 16 DRAMs are used. It 
controls the third 256 Kbyte memory bank. 


ROW ADDRESS STROBE 4 
RAS4 is used only if eight 64K by 16 DRAMs are used. It 
controls the fourth 256 Kbyte memory bank. 


OUTPUT ENABLE 
OE is the Output Enable signal for two, four and eight 
DRAM configurations. 


TABLE 4-3. SIGNAL DESCRIPTIONS (Continued) 
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WD9I0C3IA SIGNAL DESCRIPTION 


PIN NUMBER 
POFP-Morp | MNEMONIC | VO DESCRIPTION 
DISPLAY MEMORY INTERFACE (Cont.) 


WRITE ENABLE 
WE is the write enable signal for MD7 through MDO. 


WRITE ENABLE 
WE ‘1 is the write enable signal for MD15 through MD8. 


WRITE ENABLE 


WE2 is the write enable signal for MD23 through MD16. 


O WRITE ENABLE 
WES is the write enable signal for MD31 through MD24. 


PROGRAMMABLE OUTPUTS 


O May be used to control special card or system features 
(see PR32 register). 


O May be used to control special card or system features 
(see PR32 register). 





TABLE 4-3. SIGNAL DESCRIPTIONS (Continued) 
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SIGNAL DESCRIPTION WD90C31A 


PIN NUMBER 


POEP-Maorp | MNEMONIC | 1/0 DESCRIPTION 


VIDEO MEMORY DATA 





DISPLAY MEMORY DATA (MD31 through MDO) 

These lines are the data bus to the video display 
DRAMS. The MD(18:0) data lines are pulled up by inter- 
nal 50 Kohm resistors, but may be pulled down by exter- 
nal 4.7 Kohm resistors to provide setup information on 
power-up reset as follows: 


MD POWER-UP REGISTER 

FUNCTION (BIT) 
18 Enable ROM16 

as EXBLANK CNF(18) + 
16 64K by 16 or 256K by 4 
DRAM Select CNF(16) + 
EGA SW4/General Purpose PR11(7) + 
EGA SW3/General Purpose PR11(6) + 
EGA SW2/General Purpose PR11(5) + 
EGA SW1/General Purpose PR11(4) + 
ANALOG/TTL Display CNF(8) * 
Set 16-bit ROM CNF(10) * 
3C3H or 46E8H |/O port 
for wake up 
Reserved 
General Purpose 
General Purpose 
General Purpose 
General Purpose 
VCLK1,2 1/0 
AT/Micro Channel Mode 
1 or 2 ROMs 
BIOS ROM Mapping 


oOo-NMWAOTODN © 


NOTES: 

"*" Pulldown resistor sets these bits to logic 1. 

"+" Pulldown resistor sets these bits to logic 0. 

For more details refer to PR and Configuration Registers. 
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SIGNAL DESCRIPTION 














7 








PIN NUMBER | 
POFP - MOFP MNEMONIC | I/O DESCRIPTION |. 
VIDEO MEMORY ADDRESS 

61 48 MA8/RAS2 O MEMORY ADDRESS (MA&8 through MAO) 

60 47 MA7 O Display memory DRAM address. For testing purposes, 

59 46 | MA6 O these pins can be tristated by setting Register PR4(4)=1. 

58 45 MA5 O MA8/RAS2 is an active low RAS strobe for the second 

57 44. MA4 O 256 Kbyte memory bank if four 64K by 16 DRAMs are 

56 43 MA3 O used. 

55 42 MA2 O 

54 41 MA1 O 

53 40 MAO O’ 

RAMDAC INTERFACE 

126 119 .| VID7 O | VIDEO (VD7 through VDO) 

125 118 VID6 O Pixel video data output to DAC and to Feature Connector. 

124 117 VID5 O These lines can drive up to a 8 mA load. 

123 116 VID4 O 

122 115 VID3 O 

121 114 VID2 O 

120 113 VID1 0. 

119 112 VIDO O 

115 106 RPLT O READ PALETTE 
Video DAC register and color palette read signal for an 
external RAMDAC. Active low during an |/O read of ad- 
dresses 3C6H, 3C8H and 3C9H.  — 

114 105 WPLT O WRITE PALETTE 
Video DAC register and color palette write signal for an 
external RAMDAC. Active low during an I/O write to ad- 
dresses 3C6H through 3C9H. 

118 111 PCLK O PIXEL CLOCK 
Video pixel clock output used by the DAC to latch video 
signals VID7 through VIDO. Its source is one of the video 
clock inputs: VCLKO, VCLK1 or VCLK2 as determined by 
the Miscellaneous Output Register. 
CRT CONTROL 

112 103 BLANK O BLANK 
Active low display monitor blank pulse to external 
RAMDAC. 

111 102 HSYNC/ O HORIZONTAL SYNC 

HSYNC Display monitor horizontal synchronization pulse. Active 
high or low, depending on the Miscellaneous Output 
Register programming. 
TABLE 4-3. SIGNAL DESCRIPTIONS (Continued) 
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SIGNAL DESCRIPTION WD9I0C31A 


PIN NUMBER 
PQFP - MOFP MNEMONIC | I/O DESCRIPTION 
CRT CONTROL (Cont) 
110 - 101 VSYNC/ O VERTICAL SYNC 
VSYNC Display monitor vertical synchronization pulse. Active 


high or low, depending on the Miscellaneous Output 
Register programming. 

















1 - 127 MDET | MONITOR DETECT 
When the RAMDAC is external, MDET is used to deter- 
mine the monitor type and can be read at port 3C2H Bit 4. 


FEATURE CONNECTOR SUPPORT 


132 - 125 EXVID | ENABLE EXTERNAL VIDEO DATA 
A Feature Connector input. A low tristates the video data 
lines VID7:0. An internal pullup resistor is provided. 


131 - 124 EXPCLK | ENABLE EXTERNAL PIXEL CLOCK 
A Feature Connector input. A low tristates the PCLK out- 
put. An internal pullup resistor is provided. 


POWER AND GROUND 
18 2 +5VDC 
50 35 +5VDC 
84 74 +5VDC 
116 107 +5VDC 
5 13 Ground 
17 25 Ground 
29 38 Ground 
40 55 Ground 
51 71 Ground 
67 89 Ground 
83 110 Ground 
99 120 Ground 
aa e's 131 Ground 
127 143 Ground 
1 These pins are not connected in the 144-pin MQFP 
18 package 

36 

37 

54 

72 

73 

90 

108 

109 

126 

144 
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5.0 VGA/EGA REGISTERS 


All the standard IBM registers incorporated inside 
the WD90C31A are functionally equivalent to the 
VGA implementation, while additional Western Digi- 
tal registers enhance the video subsystem. Com- 
patibility registers provide functional equivalence for 
AT&T, Hercules, MDA and CGA standards defined 
earlier using the 6845 CRT Controller. This section 
describes the VGA/EGA registers. For more infor- 
mation, refer to the additional reference literature 
listed in the Table Of Contents. 


5.1 EGA MODE ENTRY 


A brief description of the procedure for entering 
EGA mode of operation is provided here. The ac- 
tual software implementation details are not 
covered in this procedure. 


¢ Load Configuration Register Bit 8. Select 
logic 0 for a VGA-compatible PS/2 display 
or logic 1 for an EGA-compatible TTL 
monitor by using the appropriate pull-up or 
pull-down resistor on MD11. Apull-up 
resistor on MD11 causes CNF(8) to be 
latched with logic 0 for analog PS/2 
compatible displays. This status information 
signifies the type of monitor attached to the 
system and is available to the BIOS or 
application. 


Unlock all the PR registers. 
Program PR2(6) to 0 for EGA mode. 


¢ Set PR4 Bit 1 to logic 1 for EGA 
compatibility. 


Load PR11(7:4) with EGA Configuration 
switches by using pull-up or pull-down 
resistors on Pins MD(15:12). (A pull-up 
resistor causes logic 1 to be latched after 
power-on-reset.) 


¢ The EGA switch setting may then be read 
from PR11(7:4) at I/O Port 3C2H Bit 4. 


VGA/EGA REGISTERS 


¢ If EGA mode is to be emulated on an IBM 
PS/2 analog display, follow the suggested 
steps listed below: 


Initialize all the registers. 

Lock CRT controller registers. 
Force clock control rate of the CRT 
controller. 


Set EGA emulation mode by 
programming: 

PR11(3) = 1; Set EGA emulation on PS/2 
type display 

PR14(6) = 1; Vertical double scan 
PR11(2) = 1; Lock clock select 

PR11(0) = 1; Lock 8/9 dot timing. 
PR14(7) = 1; Enable IRQ (optional). 


Lock the PR registers PRO through PR5 
and PR10 through PR17. 


- Read protect PR registers. 


e When EGA Is required on a TTL monitor, 
the suggested steps are: 


- |nitialize all the registers. 


- Set EGA TTL mode by programming: 
PR11(3) = 0; EGA TTL 
PR14(7) = 1; Enable IRQ 
PR15(6) = 1; Set Low Clock 
PR14(7) = 1; Enable IRQ 


- Lock PR registers PRO through PR5 and 
PR10 through PR17. 


- Read protect PR registers. 


For more details on the PR registers, refer to the 
PR registers Section 7. The EGA register sum- 
mary shown in Table 5-2 highlights all the EGA 
mode registers. 
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VGA/EGA REGISTERS WD90C31A 


© REGISTERS |@RW| MONO | COLOR | INDEX _ 


GENERAL REGISTERS Section 5.2 

















Miscellaneous Output Register 





Input Status Register 0 
Input Status Register 1 
Feature Control Register 





* Video Subsystem Enable Register. 

* |/O Port 3C3H can be used to replace 46E8H [if CNF(9) = 0] for setup in AT mode. In Micro 

Channel mode, writes to 3C3H, Bit 0 = 1 enables memory and |/O address decoding. 
SEQUENCER REGISTERS Section 5.3 


Sequencer Index Register RW 304 304 
Sequencer Data Register RW 3C5 305 00H:04H 


CRT CONTROLLER REGISTERS _ Section 5.4 


Index Register RW 3B4 3D4 
CRT Controller Data Register RW 3B5 3D5 00H:18H 


GRAPHICS CONTROLLER REGISTERS _ Section 5.5 


Index Register RW 3CE 3CE 
Other Graphics Registers RW 3CF 3CF 
ATTRIBUTE CONTROLLER REGISTERS _ Section 5.6 


RW 3C0 
W 3C0 
301 


VIDEO DAC PALETTE REGISTERS ® 



















00H:08H 












Index Register 
Attribute Controller Data Register 





00H:14H 





Section 5.7 












Write Address 
Read Address 
DAC State 
Data 

Pel Mask 


















2300/2301 
2302/2303 
23C04/23C5 


2300/23C1 
2302/2303 
23C04/23C5 


Index Controller 
Register Access Block Port 
BITBLT I/O Port 


® All Register addresses are in hexadecimal. 
@ RO = Read-Only, RW = Read/Write, W = Write, and R = Read. 
@ PR16(0) = 1 locks these registers. 










TABLE 5-1. VGA REGISTERS SUMMARY 
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; esters ‘ome| son | coe 


GENERAL REGISTERS Section 5.2 


Miscellaneous Output Register 3C2 3C2 
Input Status RegisterO — es 302 3C2 
Input Status Register 1 RO 3BA 3DA 
Feature Control Register WO 3BA 3DA 


SEQUENCER REGISTERS Section 5.3 


Sequencer Index Register WO 3C4 3C4 
Sequencer Data Register RW 3C5 3C5 01H, 03H, 
04H 


CRT CONTROLLER REGISTERS _ Section 5.4 


Index Register RW 3B4 3D4 
CRT Controller Data Register RW 3B5 ® 3D5 ® 


GRAPHICS CONTROLLER REGISTERS _ Section 5.5 


Index Register RW 3CE 3CE 

Other Graphics Register RW 3CF 3CF 04H, 05H 
ATTRIBUTE CONTROLLER REGISTERS — Section 5.6 

Index Register RW 300 3C0 


Attribute Controller Data Register W 3C0 3C0 00H:13H 
3C1 3C 1 | 


® All Register addresses are in hexadecimal. 

@ RO = Read Only, WO = Write Only, and RW = Read/Write. 

@ Miscellaneous Output Register bit 0 = 0, "B" in Monochrome modes 
Miscellaneous Output Register bitO = 1, "D" in Color modes. 





TABLE 5-2. EGA REGISTERS SUMMARY 
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VGA/EGA REGISTERS 


5.2 GENERAL REGISTERS 





WRITE 
PORT 


READ 
PORT 


REGISTER 
NAME 






Miscellaneous Output 3CC 3C2 
Input Status Register 0 3C2 a | 
Input Status Register 1 3°A ae: 











Feature Control 3CA 


NOTES 
1. Reserved bits should be set to zero. 


2. "2" Value is controlled by Bit 0 of the 


Miscellaneous Output Register and 
is programmed as follows: 


O = Bin Monochrome Modes 
1 = Din Color Modes 


3. Unless specifically identified, the 
descriptions apply to both VGA and 
EGA. 


Miscellaneous Output Register, 
VGA - Read Port = 3CCH, 
VGA/EGA - Write Port = 3C2H 


BIT FUNCTION 

7 Vertical Sync Polarity 
Select 
Horizontal Sync Polarity 
Select 

5 Odd/Even Memory Page 
Select 

3:2 Video Clock Select 


Enable Video RAM 
io: | I/O Address Select 


Bit 7 - Vertical Sync Polarity Selection. 


5.2.1 







This bit is locked if PR3(7) = 1 
0 = Positive vertical sync polarity. 


1 = Negative vertical sync polarity. 


WD90C31A 


Bit 6 - Horizontal Sync Polarity Selection. 


This bit is locked if PR3(6) = 1 
0 = Positive horizontal sync polarity. 
1 = Negative horizontal sync polarity. 


The vertical and horizontal sync polarity bits (bits 
7:6) should be set to conform with the vertical size 
of the frame used by the monitor. 


VERTICAL FRAME SIZE 
00 = Reserved 
01 = 400 lines/scan 
10 = 350 lines/scan 
11 = 480 lines/scan 


Bit 5 - Odd or Even Memory Page Select. 


When in modes 0 through 5, one memory page is 
selected from the two 64 Kbyte pages. 


O = Lower page is selected. 
1 = Upper page is selected. 


Bit 4 
Reserved. 


Bits (3:2) - Video Clock Select. 


These bits are locked if PR11(2) = 1 or if PR2(1) = 1 
and CNF(8) = 0. 


00 = Selects VCLKO for VGA/EGA applica- 
tions. For VGA, can be connected to 
allow 640 dots/line (25.175 MHz). For 
EGA, 14.318 MHz is selected. 


01 = Selects VCLK1 for VGA/EGA applica- 
tions if Configuration Register Bit 3 = 0. 
For VGA, can be connected to allow 720 
dots/line (28.322 MHz). For EGA, 
16.257 MHz clock is selected. 


10 = Selects VCLK2 (external user defined 
input) if Configuration Register Bit 3 = 0. 


11 = Reserved. Also selects VCLK2 (external 
user defined input) if Configuration 
Register Bit 3 = 0. 
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Bit 1 - VGA - System Processor Video RAM 
Access Enable. 


O = CPU access disabled. 
1 = CPU access enabled. 


- EGA - Reserved. 
Bit 0 - CRT Controller I/O Address Range 
Selection. 


Selection for Monochrome (3B4 and 3B5), or 
Color (3D4 and 3D5) mode. Bit 0 also maps Input 
Status Register 1 at MDA (8BA) or CGA (3DA). 


0 = CRTC and status addresses for MDA 
mode (3B). 


1 = CRTC and status addresses for CGA 
mode (3DX). 


5.2.2 Input Status Register 0, Read Only 


Port = 3C2H 


BIT 
Monitor Detect Bit for Color/ 
Monochrome Display 


Bit 7 - CRT Vertical Retrace Interrupt 
Pending or Cleared. 







0 = Vertical retrace interrupt cleared. 





1 = Vertical retrace interrupt pending. 


Bits (6:5) 
Reserved. 


VGA/EGA REGISTERS 


Bit 4 - VGA Mode - Monitor Detection. 


MDET monitor status is sampled and can be read 
from this bit. 


0 = Monochrome. 


1 = Color. 


- EGA Mode - Configuration Switches 
SW4-SW1 


The information stored in the four configuration 
switches in PR11 can be read at this bit if the EGA 
compatibility bit PR4(1) has been set to 1. Selec- 
tion of the bit to be read is determined by Bits 3 
and 2 of the Miscellaneous Output Register 3C2H 
as follows. 


WRITE READ 
3C2H 3C2H 
Bit 3 Bit 2 Bit 4 


(7) = EGA SW4 


) 
1(6) = EGA SW3 
) 





a 


2 


These bits may be used as general purpose 
scratch bits. 


Bits (3:0) 
Reserved. In EGA mode they must be set to 1. 


5.2.3 Input Status Register 1, Read Only 


Port = 3?AH 


[2 | Desay Erie 


Bits (7:6) 
Reserved. In EGA mode, bit 6 must be set to 1. 
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VGA/EGA REGISTERS 


Bits (5:4) - Color Plane Diagnostics. 


These bits return two of the eight video outputs 
VID7 through VIDO, as selected by Color Plane 


Enable Register Bits 5 and 4. See section 5.6.6. 


Bit 3 - Vertical Retrace Status. 


0 = Vertical frame is displayed. 
1 = Vertical retrace is active. 


Bits (2:1) 
Reserved. In EGA mode bit 2 must be Set to 1. 


Bit 0 - Display Enable Status. 


0 = CRT screen display in process. 


1 = CRT screen display disabled for horizon- 
tal or vertical retrace interval. 


5.2.4 Feature Control Register, 
VGA - Read Port = 3CAH, 
VGA/EGA - Write Port = 3?AH 


Bits (7:4) 
Reserved 











Bit 3 - VGA - Vertical Sync Control. 


0 = VSYNC output enabled. 


1 = VSYNC output is logical "OR" of VSYNC 
and Vertical Display Enable. 


- EGA - Reserved 


Bits (2:0) 
Reserved 


WD90C31A 


5.3 SEQUENCER REGISTERS 





NOTE 
Reserved bits should be set to zero. 


5.3.1 Sequencer Index Register, Read/Write 
Port = 3C4H - VGA/EGA 


PUNGTION 


4:0 Sequencer Address/ 
Index Bits 


Bits (7:5) 
Reserved. 







Bits (4:0) - Sequencer Address/index. 


The Sequencer Address Register is written with 
the index value (OOH-04H) of the Sequencer 
Register to be accessed. Sequencer extension 
registers are also indexed by this register. 


5.3.2 Reset Register, Read/Write 
Port = 3C5H, Index = 00H - VGA/EGA 


3 







Bits (7:2) 
Reserved. 
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Bit 1 - Synchronous Reset. + 


0 = Sequencer is cleared and halted 
synchronously. 


1 = Operational mode (Bit 0 = 1). 


Bit 0 - Asynchronous Reset. | * 


O = Sequencer is cleared and halted 
asynchronously. 


1 = Operational mode (Bit 1 = 1). 


yx Both bits 1 and 0 must be set to 1 for Opera- 
tional mode. 


5.3.3 Clocking Mode Register, Read/Write 
Port = 3C5H, Index = 01H 


Bits 5:2 are locked if PR11(1) = 1. 
unlocked during reads. 


3 | Sacenof 
ee 
a 
ae 
La 
on 


They appear 










Shift Load if Bit 4 = 0 
8/9 Dot Clocks 


Bits (7:6) 
Reserved. 


Bit 5 - VGA - Screen Off. 


0 = Normal screen operation. 


1 = Screen is turned off but SYNC signals 
remain active. This bit may be used to 
provide maximum display memory 
bandwidth for quick full screen updates. 


- EGA - Reserved 


VGA/EGA REGISTERS 


Bit 4 - VGA - Video Serial Shift Register 
Loading. 


O = Serial shift registers loaded every char- 
acter or every other character clock 
depending on Bit 2. 


1 = Serial shift registers loaded every 4th 
character clock (32-bit fetches). 


- EGA - Reserved 


Bit 3 - Dot Clock Selection. 


0 = Normal dot clock selected by VCLK 
input frequency. 


1 = Dot Clock divided by 2 (320/360 pixels). 


Bit 2 - Shift Load. Effective Only If Bit 4 = 0. 


0 = Video serializers are loaded every char- 
acter clock. 


1 = Video serializers are loaded every other 
character clock. 
Bit 1 


Reserved. In EGA mode bit 1 must be set to 0. 


Bit 0 - 8/9 Dot Clock. 


Commands Sequencer to generate an eight or 
nine dot wide character clock. 


This bit is locked if PR11(0) = 
0 = Nine dot wide character clock. 
1 = Eight dot wide character clock. 


5.3.4 Map Mask Register, Read/Write 
Port = 3C5H, Index = 02H - VGA/EGA 


FUNCTION 
Map 3:0 Enable 


Bits (7:4) 
Reserved. 
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Bits (3:0) - Enables Writing to Memory 


Maps 3 Through 0, Respectively. 


0 = Writing to respective Memory Map 
disabled. 


1 = Writing to respective Memory Map 
enabled. 


5.3.5 Character Map Select Register, 
Read/Write Port = 3C5H, Index = 03H 


Bits 5:0 are locked if PR11(1) = 1. They appear 
unlocked during reads. 


FUNCTION 


Reserved 


Character Map Select A 
Bits 2:0 


Character Map Select B 
Bits 2:0 





If Sequencer Register 4, Bit 1 = 1, then the at- 
tribute byte Bit 3 in text modes is redefined to con- 
trol switching between character sets. A'"0" selects 
Character Map B. A'"1" selects Character Map A. 
Character Map selection from either Plane 2 or 
Plane 3 is determined by PR2(2), PR2(5) and Bit 4 
of the attribute code. 


Bits (7:6) 
Reserved. VGA 


Bits (7:4) 
Reserved. EGA 


Bits 5, 3, 2 - VGA - Character Map A Select. 


These bits select the location of Character Map A 


as shown below. 


BITS 
532 


000 
001 
010 
O11 
100 
101 
10 
111 


MAP 


N OO FB WD MYO — O 





FONT/PLANE 2 
OR 3 LOCATION 


1st 8 KByte Block 
3rd 8 KByte Block 
sth 8 KByte Block 
7th 8 KByte Block 
2nd 8 KByte Block 
4th 8 KByte Block 
6th 8 KByte Block 
8th 8 KByte Block 


Bits (3:2) - EGA - Character Map A Select. 


These bits select the location of Character Map A 
as shown below. 


BITS 


32 
00 
01 
10 
11 


MAP 


0 
1 
2 
3 


FONT/PLANE 2 
LOCATION 


1st 8 KByte Block 
2nd 8 KByte Block 
3rd 8 KByte Block 
4th 8 KByte Block 
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Bits 4, 1,0 - VGA - Character Map B Select. 


These bits select the location of Character Map B 
as shown below. 


es [Praag 
410 3 LOCATION 

1st 8 KByte Block 
3rd 8 KByte Block 
Sth 8 KByte Block 
7th 8 KByte Block 
2nd 8 KByte Block 
4th 8 KByte Block 
6th 8 KByte Block 
8th 8 KByte Block 












NO OO BR WD DY + O 









Bits (1:0) - EGA - Character Map B Select. 


These bits select the location of Character Map B 
as shown below. 


ss [| a 
1 a LOCATION 

1st 8 KByte Block 
2nd 8 KByte Block 
3rd 8 KByte Block 


4th 8 KByte Block 







NOTE 
Character Map selection from Plane 2 is 
determined by bit 3 of the attribute code. 


5.3.6 Memory Mode Register, Read/Write 
Port = 3C5H, Index = 04H 


BIT FUNCTION 


Reserved 
Chain 4 
Odd/Even 
Extended Memory 
Reserved 











VGA/EGA REGISTERS 


Bits (7:4) 
Reserved. 


Bit 3 - VGA - Chains Four Maps. 


O = Processor sequentially accesses data 
using Map Mask Register. 


1 = Directs the two lower order video 
Memory Address pins (MA1, MAO) to 
select the map to be addressed. The. 
map selection table is shown below: 





- EGA - Reserved 


Bit 2 - VGA/EGA - Odd/Even Map Selection. 


0 = Even processor addresses to access 
Maps 0 and 2. Odd processor addresses 
to access Maps 1 and 3. 


1 = Sequential processor access as defined 
by Map Mask Register. 


Bit 1 - VGA/EGA - Extended Video Memory. 


0 = 64 KB of video memory. 


1 = Greater than 64 KB of memory for 
VGA/EGA modes. 


Bit 0 - VGA - Reserved. 
- EGA - Alpha Mode 


0 = Disables Alpha modes and enables non- 
Alpha modes. 


1 = Alpha mode is active and character map 
selection is enabled. 
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5.4 CRT CONTROLLER REGISTERS 


® ao INDEX VGA/EGA REGISTER NAME ® 6845 REGISTER NAME 


CRT Controller Address Register CRTC Address Register 
Horizontal Total Horizontal Total 

















Horizontal Display Enable End Horizontal Display 


Start Horizontal Blanking 






End Horizontal Blanking 






Start Horizontal Retrace 












End Horizontal Retrace 





Vertical Total 





+Vert. Display 
@ 
@ 
Maximum Scan Line Address 
Cursor Start 





Overflow 







Preset Row Scan 










Maximum Scan Line 
Block Cursor Start 
Block Cursor End 
Start Address High 
Start Address Low 
Block Cursor Location High 















Cursor End 
Start Address High 

Start Address Low 

Cursor Location High 
Cursor Location Low 
Light Pen High Read 
Light Pen Low Read 


Block Cursor Location Low 






Vertical Retrace Start 










Vertical Retrace End 

Vertical Display Enable End 
Offset 
Underline Location 
Start Vertical Blank 
End Vertical Blank 
CRTC Mode Control 
Line Compare 


? Value is controlled by Bit 0 of the Miscellaneous Output Register and is programmed 
as shown below: 

0 = Bin Monochrome Modes 

1 = Din Color Modes 


















6845 Mode Registers are defined and explained in greater detail in the reference literature listed in 
the Table Of Contents. 





This register can be programmed in VGA/EGA mode only. It is not applicable in 6845 mode. 







The parameters differ between the VGA and EGA modes. 





Reserved bits should be set to zero. 


TABLE 5-3. CRT CONTROLLER REGISTERS 
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5.4.1. CRT Register Index, Read/Write 
Port = 324H 


FUNCTION 











Bits (7:5) 
Reserved. 


Bits (4:0) - CRT Register Index Bits. 


These bits specify the CRT Controller register to be 
addressed. Its value is programmed in hexadecimal. 


5.4.2 Horizontal Total Register, Read/Write 
Port = 3?75H, Index = 00H 


This register is locked if register PR3(5) = 1 or the 
Vertical Retrace End Register Bit 7 = 1. 


BIT FUNCTION 
Horizontal Total Period 


Bits (7:0) - VGA - Count Plus Retrace Less 
Five. 


- EGA - Count Plus Retrace Less 
Two. 


The total character count is the total number of 
characters including retrace time per horizontal 
scan line, less 5 in VGA mode, less 2 in EGA 
mode. 


5.4.3 Horizontal Display Enable End Register, 
Read/Write Port = 3?75H, Index 01H 


This register is locked if register PR3(5) = 1 or the 
Vertical Retrace End Register Bit 7 = 1. 








FUNCTION 


7:0 Displayed Characters 
per Scan Line 


Bits (7:0) - Number Of Displayed Characters 
Less One. 





This register contains the total number of displayed 
characters less one. 


VGA/EGA REGISTERS 


5.4.4 Start Horizontal Blanking Register, 
Read/Write Port = 3275H, Index = 02H 


This register is locked if register PR3(5) = 1 or the 
Vertical Retrace End Register Bit 7 = 1. : 


FUNCTION 


Start Horizontal Blanking 


Horizontal blanking begins when the horizontal 
character counter reaches the value written in this 
register. 





5.4.5 End Horizontal Blanking, Read/Write 
Port = 325H, Index = 03H 


This register is locked if register PR3(5) = 1 or the 
Vertical Retrace End Register Bit 7 = 1. 


FUNCTION 
Reserved 


End Horizontal Blanking 
(lower 5 bits) 





Display Enable Signal 
Skew Control 


Bit 7 
Reserved 


Bits (6:5) - Display Enable Signal Skew 
Control. 


These bits define the display enable signal skew 
time in relation to horizontal synchronization pul- 
ses. The skew table is shown below: 


SKEW 
00 = 0, Character Clock Skews 
01 = 1, Character Clock Skews 
10 = 2, Character Clock Skews 
11 = 3, Character Clock Skews 
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Bits (4:0) - End Horizontal Blanking. 


VGA Mode 


These five bits, along with bit 7 of the End 
Horizontal Retrace Register (Index 05H), deter- 
mine when horizontal blanking is to end. Bits 4:0 
are the least significant bits, bit 7 is the most sig- 
nificant bit. 


When the least significant six bits of the Horizontal 
Character Counter matches these six bits, the 
horizontal blanking ends. 


EGA Mode 


These five bits, determine when horizontal blank- 
ing is to end. When the least significant five bits 
of the Horizontal Character Counter matches 
these five bits, the horizontal blanking ends. 


5.4.6 Start Horizontal Retrace Pulse 
Register, Read/Write Port = 325H, 
Index = 04H 


This register is locked if register PR3(5) = 1 or the 
Vertical Retrace End Register Bit 7 = 1. 


FUNCTION 


Character Count 





Start Horizontal Retrace 


Bits (7:0) - Start Horizontal Retrace 
Character Count. 


The character count at which the horizontal 
retrace output is to become active is programmed 
in this register as a hexadecimal value. 


5.4.7 End Horizontal Retrace Register, 
Read/Write Port = 325H, Index = 05H 


This register is locked if register PR3(5) = 1 or the 
Vertical Retrace End Register Bit 7 = 1. 
FUNCTION 
End Horizontal Blank Bit 6 


Horizontal Retrace Delay 


End Horizontal Retrace 





Bit 7 - VGA - End Horizontal Blank Bit 6. 


This is the sixth bit (Bit 5) of the End Horizontal 
Blanking Value programmed in bits 4:0 of the End 
Horizontal Blanking Register at Port 375H, Index 
03H. 


- EGA - CRT Counter Memory Address 


This bit defines whether the CRT counter memory 
address starts at an even or odd address follow- 
ing the horizontal retrace. 


O = Even Address 
1 = Odd Address 


Bits (6:5) - Horizontal Retrace Delay. 


These bits define the horizontal retrace signal 
delay. 


00 = 0, Character Clock Delay 
01 = 1, Character Clock Delay 
10 = 2, Character Clock Delays 
11 = 3, Character Clock Delays 


Bits (4:0) - End Horizontal Retrace. 


The least significant five bits are programmed in 
this register. When the least significant bits of the 
Horizontal Character Counter match these five 
bits, the Horizontal Retrace signal is turned off. 
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5.4.8 Vertical Total Register, Read/Write 
Port = 325H, Index = 06H 


This register is locked if register PR3(0) = 1, or the 
Vertical Retrace End Register Bit 7 = 1. 


FUNCTION 


Less 2 





Raster Scan Line Total 


Bits (7:0) - VGA - Raster Scan Line Total 
Less 2. 


This register contains the least significant eight 
bits of an eleven bit count of raster scan lines for a 
display frame. The programmed value includes 
the total number of vertical scan lines, minus two. 
Time for vertical retrace and vertical sync are also 
included. Bit 10 of this count is in register PR18 
at Port 375H, Index 3EH, Bit 0. Bits 9 and 8 of 
this count are loaded into the Vertical Overflow 
Register at Port 375H, Index 07H, Bit 5 and Bit 0, 
respectively. 


In 6845 mode, total vertical display time in rows is 
programmed into Bit 6 through Bit 0, while Bit 7 is 
reserved. Scan count reduction is not necessary. 
The number of scan lines in a row is determined 
by the maximum Scan Line Register (Index O9H 
Bits 4 through 0). 


- EGA - CRT Vertical Frame Time. 


This register contains the least significant eight 
bits of the CRT vertical frame time in scan lines 
including the vertical retrace. 


5.4.9 Overflow Vertical Register, Read/Write 
Port = 325H, Index = 07H 


FUNCTION 
Start Vertical Retrace 


6, 1 End Vertical Display 


Enable Bits 9:8 
5,0 Vertical Total Bits 9:8 


(5.0 | 
Line Compare Bit 8 


Start Vertical Blank Bit 8 





Bits (7:5) - EGA - 
Reserved 


@ Bits 7,2- VGA 


Start Vertical Retrace - Bits 9:8. (Bits 7:0 are at 
Index 10H.) 


® Bits 6,1-VGA 


End Vertical Display Enable - Bits 9:8. (Bits 7:0 
are at Index 12H.) 


@ Bits 5,0- VGA 
Vertical Total - Bits 9:8. (Bits 7:0 are at Index 06H.) 


Bit 4 - VGA/EGA 


Line Compare - Bit 8. (Bit 9 is at Bit 6 of index 
O9H, Bits 7:0 are at Index = 18H.) 


@ Bit 3 - VGA/EGA 


Start Vertical Blank - Bit 8. (Bit 9 is at Bit 5 of 
index 09H, Bits 7:0 are at Index =15H.) 


@ Bits 2- EGA 


Start Vertical Retrace - Bit 8. (Bits 7:0 are at Index 
10H.) 


® Bits 1- EGA 


End Vertical Display Enable - Bit 8. (Bits 7:0 are at 
Index 12H.) 


@ Bits 0- EGA 
Vertical Total - Bit 8. (Bits 7:0 are at Index 06H.) 


NOTES 
® This register is locked if Register 
PR3(1) = 0 AND the End Vertical 
Retrace Register Bit 7 = 1. 


@ This register is locked if Register 
PR3(0) = 1 OR the End Vertical 
Retrace Register Bit 7 = 1. 
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5.4.10 Preset Row Scan Register, Read/Write 
Port = 3275H, Index = 08H 


arent 


Byte Panning Control 
Preset Row Scan Count 





Bit 7 
Reserved. 


Bits (6:5) - Byte Panning Control. 


These bits allow up to three bytes to be panned in 
modes programmed as multiple shift modes. 


OPERATION 
0 0 = Normal 


0 1 = 1 Byte Left Shift 
1 0 = 2 Bytes Left Shift 
1 1=3 Bytes Left Shift 


Bits (4:0) - Preset Row Scan Count. 


These bits preset the vertical row scan counter 
once after each vertical retrace. This counter is 
incremented after each horizontal retrace period 
until the maximum row scan count is reached. 
When the maximum row scan count is reached, 
the counter is cleared. This register can be used 
for smooth vertical scrolling of text. 


WD90C31A 


5.4.11 Maximum Scan Line Register, 
Read/Write Port = 3?5H, Index = 09H 


aan 


200 to 400 Line Conversion 










Line Compare Bit 9 


Start Vertical Blank Bit 9 


In 6845 mode, Bits 7 through 5 are reserved, 





Bits (7:5) - EGA - 
Reserved 


Bit 7 - VGA - 200 to 400 Line Conversion. 


0 = Normal operation. 


1 = Activate line doubling. The row scan 
counter is clocked at half the horizontal 
scan rate to allow 200 line modes to dis- 
play 400 scan lines. Each line is double 
scanned. 


Bit 6 - VGA - Line Compare. 


This is Bit 9 of the Line Compare Register at Port 
3?5H, Index 18H. 


Bit 5 - VGA - Start Vertical Blank. 


This is Bit 9 of the Start Vertical Blank Register at 
Port 375H, Index 15H. The Vertical Blank Register 
is locked if register PR3(0) = 1. or the Vertical 
Retrace End Register Bit 7 = 1. 


Bits (4:0) - VGA/EGA - Maximum Scan Line. 


These bits are the maximum number of scanned 
lines for each row of characters. The value 
programmed is one less than the maximum num- 
ber of scanned rows per character. 


In 6845 mode, the value programmed is one less 
than the maximum scan line count for non-inter- 
lace mode. Interlaced mode is not supported. 
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5.4.12 Block Cursor Start Register, Read/Write 
Port = 325H, Index = OAH 


FUNCTION 
Block Cursor Control 


4:0 Block Cursor Start Scan 
Line 


Bits (7:6) 
Reserved. 













Bit 5 - VGA - Block Cursor Control. 


O = Block Cursor on. 
1 = Block Cursor off. 


- EGA - Reserved 


Bits (4:0) - VGA/EGA - Block Cursor Start 
Scan Line. 


These bits specify the value of the row scan 
counter within the cursor’s starting character box. 
These bits are programmed with one less than the 
value of the character row. lf these bits are 
programmed with a value greater than the Block 
Cursor End Register at Port 375H, Index OBH, no 
cursor Is generated. 


For 6845 modes, Bits 7 and 6 are reserved. Bit 5 
controls the cursor operation and Bits 4 through 0 
contain the cursor start value. 


5.4.13 Block Cursor End Register, Read/Write 
Port = 3275H, Index = OBH 






FUNCTION 
Block Cursor Skew 


4:0 Block Cursor End Scan 
Line 


In 6845 mode, Bits 7 through 5 are reserved. 






VGA/EGA REGISTERS 


Bit 7 
Reserved. 


Bits (6:5) - Block Cursor Skew Bits. 


Moves the displayed cursor to the right by the 
skew value in character clocks, e.g., one charac- 
ter clock skew moves the cursor right by one posi- 
tion on the screen. 


SKEW 
0 0 = 0 Character Clocks 


0 1 = 1 Character Clocks 
1 0 = 2 Character Clocks 
1 1 =3 Character Clocks 


Bits (4:0) - VGA - Block Cursor End 
Scanline. 


These bits specify the value of the last row scan 
counter within the character box in which the cur- 
sor is active. If this value is less than the cursor 
start value, no cursor is displayed. 


In 6845 mode Bits 4 through 0 contain the row 
value of the cursor end. 


NOTE 
There are three’ types of cursors 
generated, depending upon the mode, 
i.e, VGA, EGA or 6845 (non-VGA). The 
above description refers to the VGA cur- 
sor only. 


- EGA - Block Cursor End Scanline. 


These bits specify the Cursor End value of the last 
row scan address counter. The programmed 
value is equal to N+1 where N is the last row of 
the cursor to be displayed. 
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5.4.14 Start Address High Register, 
Read/Write Port = 325H, Index = OCH 


FUNCTION 


Start Address High Byte 


Bits (7:0) - Display Screen Start Address 
Upper Byte Bits. 





These are the high order eight bits of the 16-bit 
video memory address, used for screen refresh. 
The low order 8-bit register is at Port 325H Index 
ODH. Register PR3 Bits 4 and 3 extend this video 
memory start register to 18 bits. 


In 6845 mode, Bits 7 and 6 are forced to 0 
regardless of this register’s contents. The lower 
order eight bits are at Port 375H Index ODH. 


5.4.15 Start Address Low Register, Read/Write 
Port = 325H, Index = ODH 


FUNCTION 





Start Address Low Byte 


Bits (7:0) - Start Address Low Byte. 


These are the low order eight bits of the 16-bit video 
memory address in VGA/EGA or 6845 modes. 


5.4.16 Block Cursor Location High Register, 
Read/Write Port = 375H, Index = OEH 


FUNCTION 





7:0 Block Cursor Location 
High Byte 


Bits (7:0) - Block Cursor Address Upper 
Byte Bits. 


in VGA mode, these are the eight high order bits of 
the 16-bit cursor location. For the low order eight 
bits, see the Block Cursor Location Low Register at 
Port 375H, Index OFH. Register PR3 Bits 4 and 3 
extend the cursor location High Register to 18 bits. 


In 6845 mode, Bits 7 and 6 are reserved, while Bits 
5 through 0 are the high order bits of the cursor. 


5.4.17 Block Cursor Location Low Register, 
Read/Write Port = 3?5H, Index = OFH 


— 





7:0 Block Cursor Location 
Low Byte 


Bits (7:0) - Block Cursor Address Low 
Byte Bits. 


These are the low order eight bits of the 16-bit video 
memory address in VGA/EGA or 6845 mode. 


5.4.18 Vertical Retrace Start Register, 
Read/Write Port = 3?5H, Index = 10H 


This register is locked if register PR3(0) = 1. 


FUNCTION 
7:0 Vertical Retrace Start 
(Lower eight bits) 


Bits (7:0) - Vertical Retrace Start Pulse 
Lower Eight Bits. 





In VGA mode, these are the lower eight bits of 
the 11-bit Vertical Retrace Start Register. Bit 10 is 
located in 375H, Index 3EH, Bit 2. Bits 9 and 8 
are located in the Overflow Register at Port 3?5H, 
Index 07H. 


In 6845 compatible mode, Bits 7 and 6 are 
reserved. Bits 5 through O are read back as the 
high order six bits of the Light Pen Value. The 
lower order eight bits of the Light Pen Value are 
read back at Index 11H. 


In EGA compatible mode, this register is read 
back as the low order eight bits of the Light Pen 
Value. 
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5.4.19 Vertical Retrace End Register, 
Read/Write Port = 3?75H, Index = 11H 


IT FUNCTION 
CRTC 0-7 Write Protect 


Select 3/5 DRAM Refresh 


Enable Vertical Interrupt 
Clear Vertical Interrupt 


3:0 Vertical Retrace End. 





In 6845 compatible mode, this register reads 
back the value of the lower eight bits of Light Pen 
Register. 


Bit 7 - VGA - CRTC Registers Write Protect. 


0 = Enables writing to CRT index registers 
OOH-07H. 


1 = Write protects CRT Controller index 
registers in the range of index OOH-07H. 
Line Compare Bit 4 in the Overflow 
Register (07H) is not protected. 


- EGA - Reserved 


Bit 6 - VGA - DRAM Refresh/Horizontal 
Scan Line. 


This bit selects DRAM refresh cycles per horizon- 
tal scan line. 


O = Generates three refresh cycles for each 
horizontal scan line for normal VGA 
operation. 


1 = Generates five DRAM refresh cycles per 
horizontal scan line. 


- EGA - Reserved 


VGA/EGA REGISTERS 


Bit 5 - VGA - Enable Vertical Retrace 
Interrupt. 


0 = Enable vertical retrace interrupt. 


1 = Disable vertical retrace interrupt. 


- EGA - IRQ Output Buffer 


0 = The IRQ output buffer control is enabled. 
The IRQ latch within the CRT controller 
determines the logic state of the IRQ out- 
put signal. 


1 = The IRQ output buffer is switched to a 
high impedance state. 


Bit 4 - VGA - Clear Vertical Retrace 
Interrupt. 


0 = Clears the vertical retrace interrupt by 
writing a 0 to (resetting) an internal flip 
flop. 


1 = Vertical retrace interrupt. This allows 
an interrupt to be generated after the 
last displayed scan of the frame has 
occurred (i.e., the start of the bottom 
border). 


- EGA - IRQ Latch 


0 = The IRQ latch is reset if bit 5 = O. 


1 = The IRQ latch is set at the end of the ver- 
tical display. 


Bits (3:0) - VGA/EGA - Vertical Retrace End. 


These bits specify the scan count at which verti- 
cal sync becomes inactive. When these four bits 
match the four low-order bits of the vertical 
counter, vertical sync becomes inactive. 


Bits (3:0) are locked if register PR3(0) = 1. 
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5.4.20 Vertical Display Enable End Register, 
Read/Write Port = 3?5H, Index = 12H 






FUNCTION 
Vertical Display Enable 


End (Lower eight bits) 





Bits (7:0) - Vertical Display Enable End 
Lower Eight Bits. 


These bits define where the active display frame 
ends and are the lower eight bits of an 11-bit 
register. The programmed count is in scan lines 
minus one. Bit 10 is in Port 375H, Index 3EH, Bit 
10. Bits 9 and 8 are in the Overflow Register at 
Port 375H, Index 07H, Bits 6 and 1, respectively. 


5.4.21 Offset Register, Read/Write 
Port = 325H, Index = 13H 


BIT FUNCTION 
Logical Line Screen Width 


Bits (7:0) - Logical Line Screen Width. 


This register specifies the width of display 
memory in terms of an offset from the current row 
start address to the next character row. The offset 
value is a word address adjusted for word or 
double word display memory access. It is calcu- 
lated as follows: 


Next Row Scan Start Address equals the Current 
Row Scan Start Address, plus the product of the 
Offset Register multiplied by either 2 in the byte 
mode or 4 in word mode. 


5.4.22 Underline Location Register, 
Read/Write Port = 3?5H, Index = 14H 









FUNCTION 


re | Doubieword Mode 


Bit 7 - VGA/EGA - 
Reserved. 
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Bit 6 - VGA - Doubleword Mode. 


0 = Display memory addressed for byte or 
word access. 


1 = Display memory addressed for double 
word access. This overrides the state of 
Port 375H, Index 17H, Bit 6 (see table at 
section 5.4.25, Bit 6). 





- EGA - Reserved 


Bit 5 - VGA - Count by Four for Doubleword 
Access. 


O = Memory address counter clocked for 
byte or word access. 


1 = Memory address counter is clocked at 
the character clock rate divided by four. 


- EGA - Reserved 


Bits (4:0) - VGA/EGA - Underline Location. 


These bits specify the row scan counter value 
within a character matrix where underline is to be 
displayed. The value programmed should be one 
less than the desired scan line number. 


5.4.23 Start Vertical Blank Register, 
Read/Write Port = 325H, Index =15H 


This register is locked if register PR3(0) = 1. 


FUNCTION 


Start Vertical Blank 


(Lower eight bits) 





Bits (7:0) - Start Vertical Blank Lower 
Eight Bits. 


These are the lower eight bits of the 11-bit Start 
Vertical Blank Register. Bit 10 is in register PR18 
at Port 375H, Index 3EH, Bit 3. Bit 9 is in the 
Maximum Scan Line Register at Port 375H, Index 
O9H. Bit 8 is in the Overflow Register at Port 
3?5H, Index 07H. 


The eleventh bit value is reduced by one from the 
desired scan line count where the vertical blank- 
ing signal starts. 
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5.4.24 End Vertical Blank Register, Read/Write 
Port = 3?5H, Index = 16H 


This register is locked if register PR3(0) = 1. 


FUNCTION 
End Vertical Blank 


Bits (7:0) - VGA - Vertical Blank Inactive 
Count. 


End Vertical Blank is an eight-bit value calculated 
as follows: 


Eight-bit End Vertical Blank value = (value of Start 
Vertical Blank minus one) + (value of Vertical 
Blank signal width in scan lines). 


Bits (7:5) - EGA - 

Reserved 

Bits (4:0) - EGA - 

End Vertical Blank is a five-bit value calculated as 
follows: 


Five-bit End Vertical Blank value = (value of Start 
Vertical Blank minus one) + (value of Vertical 
Blank signal width in scan lines). 


5.4.25 CRT Mode Control Register, Read/Write 
Port = 325H, Index = 17H 


6 [Word or Byie Mode 
0 [CGACompatbity 


Bit 7 - VGA/EGA - Hardware Reset. 















0 = Horizontal and vertical retrace outputs in- 
active. 


1 = Horizontal and vertical retrace outputs 
enabled. 


Bit 6 - VGA/EGA - Word or Byte Mode. 


The state of this bit is ignored and Doubleword 
mode selected when Port 375H, Index 14H, Bit 6 
is set to 1 (See section 5.4.22 Bit 6). 


0 = Word address mode. All memory ad- 
dress counter bits shift down by one bit 
and the MSB of the address counter ap- 
pears on the LSB. 


1 = Byte address mode. 
CRT14H|CRT17H| ADDRESS 
Bit 6 Bit 6 Mode 


0 0 Word 
0 1 Byte 
| X Doubleword 


Bit 5 - VGA/EGA - Address Wrap. 





O = In word address mode, this bit enables 
Bit 13 to appear at MAO, otherwise Bit 0 
appears on MAO. 


1 = Select MA15 for odd/even mode when 
256 Kbytes of video memory are used 
on the system board. 


Bit 4 - VGA/EGA - 
Reserved. 


Bit 3 - VGA/EGA - Count by 2. 


0 = Character clock increments memory ad- 
dress counter. 


1 = Character clock divided by two incre- 
ments the address counter. 


Bit 2 - VGA/EGA - Horizontal Retrace 
Clock Rate Select for Vertical Timing 
Counter. 


This bit is locked if register PR3(5) = 1. 
0 = Selects horizontal retrace clock rate 


1 = Selects horizontal retrace clock rate 
divided by two. 
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Bit 1 - VGA/EGA - Select Row Scan Counter. 


0 = Row Scan Counter Bit 1 replaces CRTC 
when MA14 is selected to drive an ad- 
dress pin. 


1 = CRTC drives MA14 when MA14 is 
selected to drive an address pin. 


Bit 0 - 6845 CRT Controller Compatibility 
Mode Support for CGA Operation. 


0 = Row Scan Counter Bit 1 replaces CRTC 
when MA‘13 is selected to drive an ad- 
dress pin. 


1 = CRTC drives MA13 when MA13 is 
selected to drive an address pin. 


5.4.26 Line Compare Register, Read/Write 
Port = 3275H, Index = 18H 


FUNCTION 





7:0 Line Compare 
(lower eight bits) 


Bits (7:0) - Line Compare Lower Eight Bits. 


These are the lower eight bits of the ten-bit Scan 
Line Compare Register. Bit 9 is in the Maximum 
Scan Line Register at Port 375H, Index 09H. Bit 8 
is in the Overflow Register at Port 375H, Index 
07H. When the vertical counter reaches the value 
programmed in the Scan Line Compare Register, 
the internal start of the line counter is cleared. 
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5.5 GRAPHICS CONTROLLER REGISTERS 


eee [ 
(HEX) (HEX) 

3CE — Graphics Index Register 

3CF 00 Set/Reset 
Enable Set/Reset 
Color Compare 
Data Rotate 
Read Map Select 
Graphics Mode 













Miscellaneous 
Color Don’t Care 
Bit Mask 







TABLE 5-4. GRAPHICS CONTROLLER 
REGISTERS 


NOTE 
Reserved bits should be set to zero. 


5.5.1 Graphics Index Register, Read/Write 
Port = 3CEH 


FUNCTION 
Graphics Address Bits 


Bits (7:4) 
Reserved. 













Bits (3:0) - Graphics Controller Register 
Index Pointer Bits. 


NOTE 
Some of the PR registers reside with the 
index pointer extension beyond the 
standard VGA _ Graphics Controller 
registers. 
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5.5.2 Set/Reset Register, Read/Write 5.5.3 Enable Set/Reset Register, Read/Write 


Port = 3CFH, Index = 00H 


(0 [SeiRestMapo 











Port = 3CFH, Index = 01H 


BIT FUNCTION 
7:4 Reserved 


Enable Set/Reset Map-3 


Enable Set/Reset Map 2 
Enable Set/Reset Map 1 
[eo | Enable Set/Reset Map 0 





Bits (7:4) Bits (7:4) 
Reserved. Reserved. 
Bits (3:0) - Set/Reset Map. Bits (3:0) - Enable Set/Reset Register 


When the CPU executes display memory write 
with Write Mode 0 (see note below) selected, and 
the Enable Set/Reset Register at Port 3CFH Index 
01H activated, the eight bits of the bit value in this 
register, which have been operated on by the Bit 
Mask Register, are then written to the correspond- 
ing display memory map. It is an eight-bit fill 
operation. 


O = Reset. 
1 = Set. 


BIT SET/RESET 


3 Map 3 

2 Map 2 

1 Map 1 

0 Map 0 
NOTE 


The selection of Write Mode 0 is deter- 
mined by the Graphics Mode Register 
(Index = 05H) Bit 1 and Bit 0. 


Maps 3 through 0 respectively 
(Index OOH). 


0 = In Write Mode 0, each bit (3:0) when set 
to 0, disables its corresponding 
Set/Reset Register (Index = 00H) bit 
and the corresponding memory map is 
written with the rotated 8-bit data from 
the system microprocessor, as defined 
by the Data Rotate Register. 


1 = In Write Mode 0, each bit (3:0) when set 
to 1, enables memory map access 
defined by the corresponding Set/Reset 
Register (Index = 00H) bit and the 
respective memory map is written with 
the Set/Reset Register value. 
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5.5.4 Color Compare Register, Read/Write 
Port = 3CFH, Index = 02H 












Reserved 


: 


FUNCTION 





Bits (7:4) 
Reserved. 


Bits (3:0) - Color Compare. 


The Color Compare bits contain the value to 
which all eight bits of the corresponding memory 
map are compared. This comparison also occurs 
across all four maps and a 1 is returned for the 
map positions when the bits of all four maps equal 
the Color Compare Register. If a system read is 
done with Bit 3 = O for the Graphics Mode 
Register at Port 3CFH, Index 05H, data is 
returned without comparison. Color compare map 
coding is shown below. 


COLOR 
BIT COMPARE 


Map 3 
Map 2 
Map 1 
Map 0 


oO + MYO W 
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5.5.5 Data Rotate Register, Read/Write 
Port = 3CFH, Index = 03H 





Rotate Count Bit 0 


Bits (7:5) 
Reserved. 


Bits (4:3) - Function Select. 


This is the Function Select for any of the write 
mode operations defined in the Graphics Mode 
Register at Port 3CFH, Index 05H as defined 
below. 


00 = Video memory data unmodified. 


01 = Video memory data ANDed with system 
data in the latches. 


10 = Video memory data ORed with system 
data in the latches. 


11 = Video memory data XORed with system 
data in the latches. 


NOTE 
"Data" refers to CPU data that has gone 
through data rotation. The latches con- 
tain the data from the last memory read 
operation. 


Bits (2:0) - Rotate Count. 


These bits specify the number of bit positions of 
rotation to the right. Data written by the CPU is 
rotated in write mode 0, defined by the Graphics 
Mode Register at Port 3CFH, Index 05H. 
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5.5.6 Read Map Select Register, Read/Write 
Port = 3CFH, Index = 04H 


fo MapSetecto 


Bits (7:3) - VGA/EGA 
Reserved. 







Bit 2- VGA 
Reserved. 


Bits (2:0) - EGA - Map Select. 


These bits select the memory map in memory 
read operations. It has no effect on color compare 
read mode. In odd/even modes, the value is 
defined below. 


000 = Map 0 selected 
001 = Map 1 selected 
0 1 0 = Map 2 selected 
011 =Map 3 selected 


Bits (1:0) - VGA - Map Select. 


These bits select the memory map in memory 
read operations. It has no effect on color compare 
read mode. In odd/even modes, the value is 
defined below. 


0 0 = Map 0 selected 
0 1 = Map 1 selected 
1 0 = Map 2 selected 
1 1 = Map 3 selected 


VGA/EGA REGISTERS 


5.5.7 Graphics Mode Register, Read/Write 
Port = 3CFH, Index = 05H 


8 | ase caer woae 
— 

















Bit 7 - VGA/EGA - 
Reserved. 





Bit 6 - EGA - 
Reserved 


Bit 6 - VGA - 256 Color Mode. 


This bit is locked if PR11(1) = 1. 
locked during reads. 


It appears un- 


O = Enables Bit 5 of this register to control 
loading of the shift registers. Four-bit 
pixel is expanded to six bits through in- 
ternal palette and is sent out on the 
lower six bits (VID5 - VIDO) pins every 
dot clock. The remaining two video out- 
puts (VID7, VID6) are determined by 
Bits 3 and 2 of the Color Select Register 
located at Port 3C1H/3COH, Index 14H 
within the Attribute Controller. 


1 = Load Video Shift Registers to support 
256-color mode. 
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BIT 1|BITO WRITE MODE 


Write Mode 0. If the Set/Reset Register function is enabled for any of the maps, 
the eight bits of the bit value in the Set/Reset Register, which have been 
operated on by the Bit Mask Register, are then written to the corresponding dis- 
play memory map. If the Set/Reset Register function is disabled, the map is writ- 
ten with the CPU data which is rotated right by the number of bits defined in the 
Data Rotate Register (with the old LSB now the new MSB). 














Write Mode 1. This mode can be used to write the same value to many memory 
locations. The 32 bits of data in the system latches are written into each of the 
four memory maps. The system read operation loads the latches. 







Write Mode 2. Memory maps (3:0) are filled with the eight-bit value of the cor- 
responding CPU data bits (3:0). The 32-bit output of the four memory maps is 
then operated on by the Bit Mask Register and the resulting data is written to 
the four memory maps. 







Write Mode 3. Eight bits of the value contained in the Set/Reset Register (Index 
= 00H) is written into the corresponding map, regardless of the Enable Set/Reset 
Register (Index = 01H). The right rotated CPU data (see Write Mode 0) is ANDed 
with Bit Mask Register data to form an eight-bit mask value that performs the 
same function as the Bit Mask Register in Write Modes 0 and 2. 








In EGA Mode this configuration is not valid and will default to Write Mode 1. 


TABLE 5-5. WRITE MODES 


Bit 5 - VGA/EGA - Shift Register. Memory Mode Register at Port 3CFH, 

. . . Index 04H. Even system addresses ac- 
Shift Register Load controls the way in which cess Maps 2 or 0 and odd system ad- 
memory data is formatted in the four Video Shift dresses access Maps 3 or 1. 


Registers. MSB is shifted out in all cases. 


This bit is locked if PR11(1) = 1. It appears un- Bit 3- VGA/EGA - Read Mode. 


locked during reads. 
0 = System reads data from memory maps 


0 = Map 3 through Map 0 data is placed into selected by Read Map Select Register 
shift registers for normal operations. at Port 3CFH, Index 04H. This setting 
1 = For CGA graphics mode compatibility, has no effect if Bit 3 of the Sequencer 
even numbered bits from all the maps Memory Mode Register = 1. 
are shifted out of even numbered shift 1 = System reads the comparison of the 
registers, and odd numbered bits from memory maps and the Color Compare 
all the maps are shifted out of odd num- Register. 


bered shift registers. 


Bit 2 - VGA/EGA - 


Bit 4 - VGA/EGA - Odd/Even Mode. 
Reserved. 


0 = Normal é : 
Bits (1:0) - VGA/EGA - Write Mode. 


1 = CGA compatible odd/even system ac- 
cess mode. Sequential addressing as Table 5-5 defines the four write modes. 


defined by Bit 2 of the Sequencer 
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5.5.8 Miscellaneous Register, Read/Write 
Port = 3CFH, Index = 06H 


FUNCTION 


Reserved | 


ca 
ee 
ca 
! 
ca 









Memory Map 0 
Odd/Even 
Graphics Mode 





Bits (7:4) 
Reserved. 


Bits (3:2) - Memory Map 1, 0. 


Display memory map control into the CPU ad- 
dress space is shown below: 


CPU 

ADDRESS RANGE- LENGTH 
00 = AQ00:0H-BFFF:FH - 128KB 
01 = AQOO:0H-AFFF:FH - 64KB 
10 = BOOO:0H-B7FF:FH - 32KB 
11 = B800:0H-BFFF:FH - 32KB 


Bit 1 - Odd/Even Mode. 


0 = CPU address Bit AO is the memory ad- 
dress Bit MAO. 


1 = CPU address Bit Ais replaced by higher 
order address bit. AO is then used to 
select odd or even maps. AO = 0 selects 
Map 2 or 0, while AO = 1 selects Map 3 
or 1. 


Bit 0 - Graphics/Alphanumeric Mode. 


This bit is programmed the same way as Bit 0 of 
the Attribute Mode Control Register at Port 
3C1H/3COH, Index 10H. 


0 = Alphanumeric mode selected. 
1 = Graphics mode selected. 


5.5.9 Color Don’t Care Register, Read/Write 
Port = 3CFH, Index = 07H 


pit | FUNCTION 
74 [Reseved 
8 | Memory Maps 
aaa 
i 
fo 









Memory Map 2 
Memory Map 1 
Memory Map 0 





Bits (7:4) 
Reserved. 


Bits (3:0) - Memory Map Color Compare 
Operation. 


0 = Disable color compare operation. 
1 = Enable color compare operation. 


5.5.10 Bit Mask Register, Read/Write 
Port = 3CFH, Index = 08H 


BIT FUNCTION 


Bits (7:0) - Bit Mask. 


Bit Mask operation applies simultaneously to all 
four maps. In Write Modes 2 and 0, this register 
provides selective changes to any bit stored in the 
system latches during processor writes. Data 
must be first latched by reading the addressed 
byte. After setting the Bit Mask Register, new 
data is written to the same byte in a subsequent 
operation. Bit mask operation is applicable to any 
data written by the processor. 


0 = Bit position value is masked or is not 
changeable. 


1 = Bit position value is unmasked and can 
be changed in the corresponding map. 
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ATTRIBUTE CONTROLLER REGISTERS 


PORT | INDEX 
(HEX) —— 
Index Register 
VGA - Palette Pixel Colors 


EGA - Dynamic Color 
Selection 


Attribute Mode Control 
Register 













Overscan Control Register 





Color Plane Enable 
Register 


Horizontal PEL Panning 
Register 








Color Select Register 


TABLE 5-6. ATTRIBUTE CONTROLLER 
REGISTERS 


NOTES 

1. The Attribute Index Register has an in- 
ternal flip-flop rather than an input bit 
to control the selection of the Ad- 
dress and Data Registers. Reading 
the Input Status Register 1 (Port 
3?AH) clears the flip-flop and selects 
the Address Register, which is read 
at address 3C1H and written at ad- 
dress 3COH. Once the Address 
Register has been loaded with an 
index, the next write operation to 
3COH loads the Data Register. The 
flip-flop toggles between the Address 
and the Data Registers after every 
write to address 3COH but does not 
toggle for reads from address 3C1H. 





2. Attribute Register data is written at 
3COH and register data is read from 
address 3C1H. 


3. Reserved bits should be set to zero. 
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5.6.1 Attribute Index Register, Read/Write 
Port = 3C0OH 


Bits (7:6) 
Reserved. 














Bit 5 - Palette Address Source. 


0 = Disable internal color palette outputs 
and video outputs to allow CPU access 
to Color Palette Registers Port 3COH, 
Index 00 - OFH. 


1 = Enable internal color palette and normal 
video translation. 


Bits (4:0) - Attribute Controller Index 
Register Address Bits. 


5.6.2 VGA - Palette Registers, 
Read Port = 3C1H, Write Port = 3COH, 
Index 00-0FH 


These registers are locked if PR4(2) = 1. 


cer | runcrion 
a 
an 
re 
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Bits (7:6) 
Reserved. 


Bits (5:0) - Palette Pixel Colors. 


Bits 5 through O control VID5 through VIDO 
respectively. 


They are defined as follows: 
O = Current pixel color deselected. 
1 = Enables the corresponding pixel color. 


5.6.3 EGA- Dynamic Color Registers, 
Read Port = 3C1H, Write Port = 3COH, 
Index 00-OFH 


These registers are locked if PR4(2) = 1. 
Bits (7:6) 

Reserved. 

Bits (5:0) - Dynamic Color Selection. 


Bits 5 through 0 are defined as follows: 
O = Color deselected. 
1 = Color selected. 


Bit Color Pixel 
5 Secondary Red VID5 
4 Secondary Green/Inten. VID4 
3 Secondary Blue/Mono VID3 
2 Red VID2 
1 Green VID1 
O Blue VIDO 


VGA/EGA REGISTERS 


5.6.4 Attribute Mode Control Register, 
Read Port = 3C1H, Write Port = 3COH, 
Index = 10H 


FUNCTION 
| 7 | VIDS, VID4 Select 
| 6 | PEL Width 
5 PEL Panning 
Compatibility 
3 Enable Blink/Select Back- 
ground Intensity 
2 Enable Line Graphics 
Character Code 


















Mono-Emulation 


Graphics/Alonanumeric 
Mode 


Bits (7:4) - EGA - 
Reserved. 





Bit 7 - VGA - VID5, VID4 Select. 


0 = VID5 and VID4 palette register outputs 
are selected. 


1 = Color Select Register Port 3C1H/3COH, 
Index 14H, Bits 1 and 0 are selected for 
outputs at VID5 and VID4 pins. 


Bit 6 - VGA - Pixel Width. 


0 = Disable 256 color mode pixel width. The 
PCLK output is the same as the internal 
dot clock rate. 


1 = Enable pixel width for 256 color mode. 
The PCLK output is the internal dot 
clock divided by two. 


Bit 5 - VGA - PEL Panning Compatibility. 


Line Compare in the CRT Controller. 


0 = ALine compare will have no effect on 
the PEL Panning Register. 


1 = Allows a successful line compare to dis- 
able the PEL Panning Register and Bits 
6 and 5 of the CRT Controller Register 
08 until VSYNC occurs. Allows pixel 
panning of a selected portion of the 
screen. 
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Bit 4- VGA 
Reserved. 


Bit 3 - VGA/EGA - Background 
Intensity/Blink Selection. 


0 = Selects background intensity from the 
MSB of the attribute byte. 


1 = Selects blink attribute. 


Bit 2 - VGA/EGA - Enable Line Graphics 
Character Code. 


This bit should be set to zero for character fonts 
that do not utilize line graphics character codes. 


0 = Forces the ninth dot to be the same 
color as the background in line graphics 
character codes. 


1 = Used in MDA line graphics modes. The 
ninth dot character is forced to be identi- 
cal to the eighth character dot. 

Bit 1 - VGA/EGA - Mono/Color Emulation. 


0 = Color display attributes. 
1 = MDA attributes. 


Bit 0 - VGA/EGA - Graphics/Alphanumeric 
Mode Enable. 


0 = Alphanumeric mode. 
1 = Graphics mode. 


WD90C31A 


5.6.5 Overscan Color Register, Read 
Port = 3C1H, Write Port = 3COH, 
Index = 11H 


This register is locked if PR4(2) = 1. 


~e vos 















ViD2 
2 [veo 


Bits (7:0) - VGA - Overscan/Border Color. 






These bits determine the overscan or border 
color. For monochrome display, this register is set 
to 0. Border colors are set as shown above. 


Bits (7:6) - EGA - 
Reserved. 


Bits (5:0) - EGA - Overscan/Border Color. 


For a monochrome display, Bits 5:0 = 0. 


For the border color, refer to Bits (5:0) in the 
Dynamic Color Selection in section 5.6.3. 


5.6.6 Color Plane Enable Register, Read 
Port = 3C1H, Write Port = 3COH, 
Index = 12H 


FUNCTION 
Reserved 


Video Status Multiplexer 





Color Plane Enable 


Bits (7:6) - VGA/EGA - 
Reserved. 
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Bits (5:4) - VGA - Video Status Multilexer 


These bits select two out of eight color outputs 
which can be read by the Input Status Register 1 
at Port 37AH, Bits 5 and 4. See section 5.2.3. 


COLOR PLANE | INPUT STATUS 
REGISTER REGISTER 1 
BIT5 | BIT4 | BITS | BIT4 


0 0 
0 1 
1 0 
1 1 


Bits (5:4) - EGA - Video Status Multiplexer 

























These bits select two out of six color outputs 
which can be read by the Input Status Register 1 
at Port 37AH, Bits 5 and 4. See section 5.2.3. 


COLOR PLANE | INPUT STATUS 
REGISTER REGISTER 1 
BIT5 | BIT4 | BITS | BIT4 

0 0 


VIDO 
Blue 


VID4 
SGreen 


VID1 
Green 


VID4 
SGreen 














Bits (3:0) - VGA/EGA - Color Plane Enable. 


0 = Disables respective color planes. Forces 
pixel bit to 0 before it addresses palette. 


1 = Enables the respective display memory 
color plane. 
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5.6.7 Horizontal Pel Panning Register, 
Read Port = 3C1H, Write Port = 3COH, 
Index = 13H 


BIT FUNCTION 
Horizontal PEL Panning 


Bits (7:4) - VGA/EGA - 
Reserved. 










Bits (3:0) - Horizontal Pixel Panning. 


- VGA - 


Horizontal Pixel Panning is available in text or 
graphics modes. These bits select pixel shift to 
the left. For nine dots/character modes, up to 
eight pixels can be shifted. Likewise, for eight 
dots/character modes, up to seven pixels can be 
shifted. For 256 color, up to three position pixel 
shifts can occur. The following table defines the 
shift in different modes. 


- EGA - 


These four bits determine the horizontal left shift 
of the video data in number of pixels. In 
monochrome alphanumeric modes, (nine 
dots/character) image can be shifted by nine 
pixels. For all other graphics or alphanumeric 
modes, a maximum left shift of eight pixels is per- 


mitted. 
9 Dots 8 dots 256 
Character | Character Color 
Mode 


Register 
Value 


CON DOP WD DH — 
N OO OF ff W MH + O 


0 
1 
2 
3 
4 
5 
6 
7 


© 
© 
' 
1 


TABLE 5-7. LEFT SHIFT PIXEL VALUE 
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5.6.8 Color Select Register, 
Read Port = 3C1H, Write Port = 3COH, 
Index = 14H 


eo 
















S_ Color 5 





Bits (7:4) 
Reserved. 


Bits (3:2) - Color Value MSB. 


These are the two most significant bits of the 
eight-digit color value for the video DAC. They 
are normally used in all modes except 256 color 
graphics. 


Bit 3 = Set color bit VID7. 
Bit 2 = Set color bit VID6. 






PEL Address Port (Read) 
*DAC State (Read Only) 







3C7H 
*8C7H 





* This port is internal to the WD90C31A. 


DAC 
ADDRESS DAC OPERATION DETAILS 


3C8H PEL Address Port (Write) Read/Write Port 






3C6H PEL Mask (Read/Write) Not to be written to by application code. 
To do so changes the color look-up table. 


3C9H PEL Data Register (Read/Write) | Three successive read/write bytes. 
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Bits (1:0) - Substituted Color Value Bits. 


These bits can be substituted for VID5 and VID4 
output by the Attribute Controller palette registers, 
to create eight-bit color value. They are selected 
by the Attribute Controller Mode Control Register 
at Port 3COH, Index 10H. 


5.7 VIDEO RAMDAC PORTS 


The Video RAMDAC is implemented externally to 
the WD90C31A. However, the WPLT and RPLT 
signals required by the RAMDAC are provided by 
the WD90C31A. Setting PR16 Bit 0 to 1 de-asserts 
WPLT disabling I/O writes to the RAMDAC. Nor- 
mally, the WPLT and RPLT signals to the RAM- 
DAC are generated when the |/O ports illustrated 
in table 5-8 are written to or read from. 












Read Only Port 


* If Bits 1:0 = 1, DAC is in read operation. 
When Bits 1:0 = 0, DAC is in write opera- 
tion. Bits 7:2 are reserved. 








TABLE 5-8. VIDEO RAMDAC PORTS 
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6.0 COMPATIBILITY REGISTERS 


NOTES | 
1. The Compatibility Registers are avail- 
pone’) able only in 6845 mode (non-VGA), 
which is enabled by setting register 
PR2(6) = 1. 


2. The AT&T/M24 Register also requires 
that M24 mode be enabled. This is 
AT&T/M24 Register done by setting register PR2(7) = 1. 


Hercules Register 3. "2" Value is controlled by Bit 0 of the 

Preset Light Pen Latch | 3B9 (Mono) Miscellaneous Output Register at 
3DC (CGA) Port 83CCH/3C2H and is 

Clear Light Pen Latch | 37B ee 

1 = Din Color Modes. 


Mode Control Register 


Color Select Register 


Status Register 





3D8 3D8 


Mode Control Register WO 





















3B8 3B8 



























Color Select Register WO 3D9 3D9 
Status Register RO 3BA 3DA 3DA 
Preset Light Pen Latch WO 3B9 3DC 3DC 
Clear Light Pen Latch WO 3BB 3DB 3DB 
AT&T/M24 Register WO 3DE 
Hercules Register WO 3BF 








+CRTC RW 3D0-3D7 3D0-3D7 3B0-3B7 


NOTES: 
1. RO = Read-Only, WO = Write-Only, RW = Read/Write. 
2. All Register addresses are in hex. 
3. + = 6845 Mode Registers. 


3B0-3B7 










TABLE 6-1. COMPATIBILITY REGISTERS SUMMARY 
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6.1 HERCULES/MDA MODE CONTROL 
REGISTER, MDA OPERATION WRITE 
ONLY PORT = 3B8H 


Memory Page Select 
(6 | Resewed 
















Reserved 


Reserved/ Port 3BFH 
Enable 
| 0: | High Resolution Mode 


Bit 7 - Select Display Memory Page 
Address in Hercules Mode. 





Reserved in MDA mode. 


In Hercules Graphics mode, this bit selects the 
Display Memory Page if Bit 1 of this register is 1 
and Bit 0 in Port 3BFH is 0. 


0 = Display memory page adaress starts at 


BOO00:0H. 
1 = Display memory page address starts at 
B800:0H. 
Bit 6 
Reserved. 


Bit 5 - Enable Blink. 


0 = Disable Blinking. 
1 = Enable Blinking. 


Bit 4 
Reserved. 
Bit 3 - Video Enable. 


0 = Video Disabled. 
1 = Video Activated. 


Bit 2 
Reserved. 


WD90C31A 


Bit 1 - Port 3BFH Enabled. 


O = Prevents setting of Port 3BFH Bits 1:0, 
thereby forcing the alpha mode opera- 
tion. 


1 = Allows the Port 3BFH Bits 1:0 to switch 
for the alpha or graphics mode selection. 


Bit 0 - High Resolution Mode. 


Should be set to "1". 
0 = High resolution disabled. 
1 = High resolution is enabled. 


6.2 HERCULES REGISTERS 


The Hercules Mode Register is a two-bit write only 
register located at I/O port address 3BFH. It af- 
fects the device operation only in the 6845 mode. 
The Enable Mode Register located at address 
3B8H overrides the write port 3BFH functions 
defined by its Bits 1 and 0. 


6.3 ENABLE MODE REGISTER PORT 3B8H 


FUNCTION 
7 Display Memory Page 
Address Graphics Mode 


es 







Video Enable 
Port 3BF Bit 0 Override 


High Resolution 
Mode = 1 


Bit 7 - Select Display Memory Page 
Address in Graphics Mode. 







0 = Display memory page address starts at 
BOO0:0H. 


1 = Display memory page address starts at 
B800:0H. 
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Bits (6:2, 0) 
Not applicable in Hercules Mode. 


Bit 1 - Port 3BFH, Bit 0 Override. 


0 = Prevents setting of Port 3BFH, Bit 0, 
thereby forcing the Alpha Mode operation. 


1 = Allows the Port 3BFH, Bit 0 to switch for 
the Alpha or Graphics Mode selection. 


6.4 HERCULES COMPATIBILITY 
REGISTER, WRITE ONLY PORT = 3BFH 


This register is locked if PR17(1) = 1 


ca 








Upper Memory Page Address 
Enable Graphics 





Bits (7:2) 
Reserved. 


Bit 1 - Upper Memory Page Address. 


In the graphics mode, Bit 7 of the Enable Mode 
Control Register at Port 3B8H selects the dis- 
played memory page address. When that bit is 
reset, Bit 1 of this register prevents access to the 
second memory page, located at B800:0H for the 
32 Kbyte memory space. 


O = Upper memory page is mapped out. 
1 = Upper memory page is accessible. 


Bit 0 - Enable Graphics. 


Bit 1 of Enable Mode Register at Port 3B8H may 
prevent setting this bit, thereby selecting Alpha 
Mode display. 


0 = Alpha mode display. 
1 = Graphics modes may be displayed. 


COMPATIBILITY REGISTERS 


6.5 COLOR CGA OPERATION REGISTER, 
WRITE ONLY PORT = 3D8H 











BIT FUNCTION 
7:6 Reserved 


Enable Blink 


B/W Graphics Mode 


Enable Video 


B/W/Color Mode Select 


Graphics/Alpha Mode 
Select 
om (40 by 25) or (80 by 25) 


Alpha Mode 
Bits (7:6) 


Reserved. 














Bit 5 - Enable Blink Function. 


0 = Disables blinking function. 
1 = For normal operation, set this bit to allow 
blinking. 
Bit 4 - B/W Graphics Mode Enable. 


0 = Deselect 640 by 200 B/W graphics 
mode. 


1 = Enable 640 by 200 B/W graphics mode. 


Bit 3 - Enable Video Signal. 


0 = Deactivates video signal. This is done 
during mode changes. 


1 = B/W mode enabled. 

Bit 2 - B/W or Color Display Mode. 
O = Color mode selected. 
1 = B/W mode selected. 


Bit 1 - Graphics or Alpha Mode Selection. 


0 = Alpha mode selected. 
1 = Graphics mode (320 by 200) selected. 
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Bit 0 - (40 by 25) or (80 by 25) Alpha Mode 
Selection. 


0 = 40 by 25 alpha mode selected. 
1 = 80 by 25 alpha mode selected. 


6.6  CGACOLOR SELECT REGISTER, 
WRITE ONLY PORT = 3D9H 


2 
1 


Alternate Color Set 


High Intensity Component 
Red Component 


re. Green Component 
[oO  | Blue Component 


Bits (7:6) 
Reserved. 





Bit 5 - 320 by 200 Color Set Select for the 
CGA (two bits per pixel). 


0 = Background, green, red, brown colors. 
1 = Background, cyan, magenta, white 
colors. 


Bit 4 - Alternate Color Set Enable. 


0 = Background color in aloha mode. 


1 = Enable alternate color set in graphics 
mode. 
Bit 3 - High Intensity Component. 


Border color select in text modes and screen 
background color in 320 by 200 and 640 by 200 
graphics mode. 


Alphanumeric mode. 


0 = No selection. 


1 = Selects intensified border color. 


320 by 200 Graphics Mode. 


O = No selection. 


1 = Selects intensified background and bor- 1/7 
der color. 


640 by 200 Graphics Mode. 





O = No selection. 


1 = Selects red foreground color. 


Bit 2 - Red Component. 


Border color select in text modes and screen 
background color in 320 by 200 and 640 by 200 
graphics mode. 


Alphanumeric Mode. 

0 = No component added. 

1 = Red component added to border color. 
320 by 200 Graphics Mode. 


0 = No component added. 


1 = Red component added to background 
and border color. 


640 by 200 Graphics Mode. 


0 = No component added. 
1 = Red component added to foreground 


color. 
Bit 1 - Green Component. 


Border color select in text modes, and screen 
background color in 320 by 200 and 640 by 200 
graphics mode. 


Alphanumeric Mode. 

0 = No component added. 

1 = Green component added to border color. 
320 by 200 Graphics Mode. 


0 = No component added. 


1 = Green component added to background 
and border color. 
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640 by 200 Graphics Mode. 


0 = No component added. 


1 = Green component added to foreground 
color. 


Bit 0 - Blue Component. 


Border color select in text modes and screen 
background color in 320 by 200 and 640 by 200 
graphics mode. 


Alphanumeric Mode. 


0 = No component added. 
1 = Blue component added to border color. 


320 by 200 Graphics Mode. 


0 = No component added. 
1 = Blue component added to background 
and border color. 


640 by 200 Graphics Mode. 


0 = No component added. 


1 = Blue component added to foreground 
color. 


6.7 CRT STATUS REGISTER, MDA OPERA- 
TION, READ ONLY PORT = 3BAH 


(0 | Display Enabe naive 


Bit 7 - Vertical Retrace. 








0 = Indicates that the raster is in vertical 
retrace mode. 


1 = Indicates vertical retrace is inactive (in- 
verted VSYNC if I/O is mapped into 
3BX). 


COMPATIBILITY REGISTERS 


Bits (6:4) 
Reserved. 


Bit 3 - B/W Video Status. 


0 = B/W Video disabled. 
1 = B/W Video enabled. 


Bits (2:1) 
Reserved. 


Bit 0 - Display Enable. 


0 = Display Enable is active. 


1 = Indicates that the screen border or blank- 
ing is active, Display Enable is inactive. 


6.8 CRT STATUS REGISTER, CGA OPERA- 
TION, READ ONLY PORT = 3DAH 


oa 













Light Pen Switch Status 
Light Pen Latch Set 


Display Enable Inactive 





Bits (7:4) 
Reserved. 


Bit 3 - Vertical Retrace. 


O = Indicates that vertical retrace is inactive. 


1 = Indicates that the raster is in vertical 
retrace mode. 


Bit 2 - Light Pen Switch Status. 
0 = Light pen switch closed. 
1 = Light pen switch open 

Bit 1 - Light Pen Latch. 


0 = Light pen latch cleared. 
1 = Light pen latch set. 
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Bit 0 - Display Enable. 


0 = Display Enable is active. 


1 = Indicates that the screen border or blank- 
ing is active, Display Enable is inactive. 


6.9 AT&T/M24 REGISTER, WRITE ONLY 
PORT = 3DEH 


This is a write only, eight-bit register located at 
address 3DEH. It is used to control the 640 by 
400 AT&T graphics mode. All bits are set to zero 
by reset. This register is enabled by setting Bit 7 


in register PR2. 
6 | WhiteBlue Underine 
a 
















Bits (7, 5, 4, 1) 
Reserved. 





Bit 6 - White/Blue Underline. 


Defines underline attribute according to the MDA 
display requirements. 


0 = Underline attribute selects blue 
foreground in color text modes. 


1 = Underline attribute selects white under- 
lined foreground. 


WD90C31A 


Bit 3 - Page Select. 


Selects between one or two 16 Kbyte RAM page 
for display in 200 line graphics mode. 


0 = Display memory address starts at 
B800:0H (16 Kbyte length). 


1 = Display memory address starts at 
BCO00:0H (16 Kbyte length). 





Bit 2 - Character Set Select. 


Selects between two character font planes. 
O = Standard character font from plane 2. 


1 = Alternate character font from plane 3. 


Bit 0 - M24 or Non-IBM Graphics Mode, 
400-line Mode. 
A 400-line monitor is required for this mode. 


0 = 200-line graphics mode active, using 
paired lines. 


1 = AT&T mode enabled for 400-line 
graphics. 
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7.0 PR REGISTERS 


The WD90C31A has additional features that en- 
hance the performance and function of the earlier 
Western Digital Imaging video controllers and the 
basic VGA subsystem. To accomplish this, the 
WD90C31A ‘architecture is optimized with addi- 
tional I/O registers. 


The registers are at the I/O locations unused by 
IBM. All registers are read/write, except where 
noted. 


NOTES 
1. The designation 375H means that 
the register is mapped into either 
3B5H in monochrome mode or 3D5H 
in color modes. 


2. PR Register notation - XXX.YY when 
XXX is the data port address and YY 
is the register index, e.g., 3CF.OF im- 
plies OF — 3CEH (Select Index 
register) followed by (Data byte) 
— 3CFH (Data Port). Registers 
PR(0:4) and PR(11:1A) are normally 
locked. They are write protected at 
power-up by the hardware reset. In 
order to load 


~~ 


PR REGISTERS 


those registers, the appropriate un- 
lock register PR5 or PR10 must be 
loaded first with binary XXXXX101. A 
register remains unlocked until 
another value is written to the unlock- 
ed register. Registers PR(0:5) are 
readable only if PR4 Bit 1 = 0. 
Registers PR(10:17) are read 
protected at power up by hardware 
reset. In order to read registers 
PR(10:17), load PR10 with 
1XXXOXXX. The register remains 
readable until any other value is writ- 
ten to PR10. When registers 
PR(10:17) are read protected, read- 
ing them would show data to be FFH. 
Setting PR4 Bit 1 to "1" does not 
read protect registers PR(10:17). 
PR(21:23) and PR(30:35) are R/W 
protected by PR20. PR20 must be 
loaded with 48H to make it possible 
to read or write to PR(21:23) and 
PR(30:35). All PR registers are set 
to "0" at power on reset except 
where noted. 





17-56 9/3/92 








PR REGISTERS 


WD9I0C31A 





REGISTERS 2 MONOCHROME COLOR 







PRO(A) Address Offset A 


3CF.09 








3CF.09 





























































PRO(B) Alternate Address Offset B 3CF.0A 3CF.0A 
PR1 Memory Size 3CF.0B 3CF.0B 
PR2 Video Select 3CF.0C 3CF.0C 
PR3 CRT Control 3CF.0D 3CF.0D 
PR4 Video Control 3CF.0E 3CF.0E 
PR5 Unlock (PRO-PR4)/Status 3CF.OF 3CF.0F 
PR10 Unlock (PR11-PR17) 3B5.29 3D5.29 
PR11 EGA Switches 3B5.2A 3D5.2A 
PR12 Scratch Pad 3B5.2B 3D5.2B 
PR13 Interlace H/2 Start 3B5.2C 3D5.2C 
PR14 Interlace H/2 End 3B5.2D 3D5.2D 
PR15 Miscellaneous Control 1 3B5.2E 3D5.2E 
PR16 Miscellaneous Control 2 3B5.2F 3D5.2F 


PR17 Miscellaneous Control 3 3B5.30 3D5.30 











3B5.31-3B5.3C | 3D5.31 -3D5.3C 





Reserved 375.31- 325.3C 





































PR18 CRTC Vertical Timing Overflow 3B5.3E 3D5.3E 























PR19 Signature Analyzer Control 3B5.3F 3D5.3F 
PR1A CRTC Shadow Register Control 3B5.3D 3D5.3D 
PR20 Unlock Sequencer Extended Registers 305.06 305.06 
PR21 Display Configuration and Scratch Pad 3C5.07 3C5.07 
PR22 Scratch Pad 3C5.08 305.08 
PR23 Scratch Pad 3C5.09 305.09 
PR30 Memory Interface write buffer and FIFO Control 305.10 305.10 
PR31 System Interface Control 305.11 305.11 

PR32 Miscellaneous Control 4 305.12 305.12 
PR33 DRAM Timing and Zero Wait State Control 305.13 305.13 
PR34 Video Memory Mapping 305.14 305.14 
PR35 Reserved 305.15 305.15 






NOTE: 
All of the PR Registers may be read/write protected. Refer to the PR Registers description for more 
details. 







A register description from locations such as 3CF.09 is the value read from or written to location 3CFH, 
after a value of 09 has been written to the corresponding Index register 3CEH. 





"2" Value is controlled by Bit 0 of the Miscellaneous Output Register at Port 3CCH/3C2H and is 
programmed as shown below: 
O = B in Monochrome Modes 

1 = Din Color Modes. 






TABLE 7-1. PR REGISTERS SUMMARY 
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7.1. ADDRESS OFFSET REGISTERS PROA 
AND PROB 


PROA - Address Offset Register A, 
Read/Write Port = 3CFH, Index = 09H 


This register is locked if PR5(2:0) = 5. 


BIT FUNCTION 
7:0 Primary Address Offset 
| Bits 


PROB - Address Offset Register B, 
Read/Write Port = 3CFH, Index = OAH 


This register is locked if PR5(2:0) = 5. 





BIT FUNCTION 





7:0 Alternate Address Offset 
Bits 


The WD90C31A can control up to 1 Mbyte of dis- 
play memory. However, DOS only assigns 128 
Kbytes total memory space for display memory, 
which starts at AOOOOH and ends at BFFFFH. To 
help VGA reach the memory beyond this range, 
the WD90C31A has two CPU address offset 
registers, PROA and PROB which can be used to 
support more than 128 Kbytes of linear display 
memory address space. 


The contents of PROA (Bits 7:0) or PROB (Bits 
7:0) are always added to the CPU address 
A(19:12) before they are translated to display 
memory address. This can be thought of as seg- 
ment register DS and ES in the 8088/80X86 ar- 
chitecture. PROA and PROB will then provide 
four Kbyte segmentation of the display memory. 
(Increment PROA or PROB by one of its 
equivalents to jump from a four Kbyte segment to 
another four Kbyte segment of the display 
memory.) 


PR REGISTERS 


PROA and PROB are all set to zero at power-on- 
reset. There are two ways to control whether 
PROA or PROB get added into CPU address. 


¢ Sequencer Extension Register 3C5H, 
Index = 11H, Bit 7 = 0. 


When PR1-3 = 0, PROA is always selected as 
the CPU address offset register. 


When PR1-3 = 1 and the display memory is 
mapped into AQOO - BFFFF (128 Kbytes), 
PROA offset CPU address range is BOOOO - 
BFFFF, the PROB offset CPU address range is 
AQOOO - AFFFF. (If CPU address bit A16 = 1, 
select PROA. Otherwise PROB is selected.) 


When PR1-3 = 1 and the display memory is 
mapped into AOOOO - AFFFF (64 Kbytes) or 
BOOOO - B7FFF or B800 - BFFFF (32 Kbytes), 
then PROB offset CPU address range is AO000 
- A7FFF or BO000 - B7FFF. PROA offset CPU 
address range is A8000 - AFFFF or B8000 - 
BFFFF. (lf CPU address bit A15 = 1, select 
PROA. Otherwise PROB is selected.) 


¢ Sequencer Extension Register 3C5H, 
Index = 11H, Bit 7 = 1. 


Both PROA and PROB are enabled. A CPU 
memory write selects PROB as the offset 
register. Otherwise, PROA is selected as the 
offset register. 
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7.2 PR1- MEMORY SIZE, READ/WRITE This register is eight bits wide. Bits PR1(1:0) are 
PORT = 3CFH, INDEX = OBH latched internally at power on reset from the cor- 
This register is locked if PR5(2:0) = 5. responding memory data bus pins MD10, MDO, 


using either pull-up or pull-down external resis- 
tors. Pull-up resistors on MD10, MDO cause 
PR1(1:0) bits to be latched low. 












Enable Alternate Address 
Offset Register PROB. 
16-Bit System Interface 


16-bit BIOS ROM 
0 BIOS ROM Map Out 


Bits (7:6) - Memory Size. 





These two bits control memory size and memory 
organization. They both must be set to reflect the 
amount of memory installed. These bits, in con- 
junction with PROA, PROB, PR16(1), select the 
way memory is mapped into the CPU address 
space. IF PR16(1) is set to 1, the memory map- 
ping will be set identical to the IBM VGA, regard- 
less of PR1(7), PR1(6). 


Tables 7-2 through 7-5 list the different settings on 
these two bits for different memory organizations. 



















PR1(7) =0 PR1(6) =0 256K TOTAL, IBM VGA MEMORY ORGANIZATION 


ADDRESS FROM CPU OR CRTC ADDRESS TO VIDEO 
MEMORY 
BYTE WIDE WORD WIDE 


CPU CRT/BITBLT | CPU CRT/BITBLT | CPU 
PA 













$ 
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A(t) | CA(A) A(1) A(15) | CA(13) 
A(0) | CA(0) 4 A(14) | CA(12) MA(0) 





TABLE 7-2. IBM COMPATIBLE MEMORY ORGANIZATION 
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PR1(7)=0 PR1(6) =1 256K TOTAL, 64K/PLANE, WD90C31A MEMORY ORGANIZATION 


ADDRESS FROM CPU OR CRTC ADDRESS TO VIDEO 
MEMORY 


BYTE WIDE WORD WIDE DOUBLE WORD WIDE 
CPU | CRT/BITBLT CRT/BITBLT CRT/BITBLT 
SS a ee 


fo fe fe fo Jo fo 
rats) | cas) | ais) | catia) |) | CAG) | MACS 
WAC) 
ee Cee Coe ce as ea! 
ane Sa SE SE SN SN 
aa 
0 A(16) 


CA( ) 
A(0) CA(O CA(15) (16) MA(0) 





TABLE 7-3. WD90C31A MEMORY ORGANIZATION - 256 KBYTES 


PR1(7) = 1 PR1(6) =0 512K TOTAL, 128K/PLANE, WD90C31A MEMORY ORGANIZATION 


ADDRESS FROM CPU OR CRTC ADDRESS TO VIDEO 
MEMORY 


BYTE WIDE WORD WIDE | DOUBLE WORD WIDE 
CRT/BITBLT - CRT/BITBLT = eee 
moe [om fm PA 





TABLE 7-4. WD90C31A MEMORY ORGANIZATION - 512 KBYTES 
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PR1(7) = 1 PR1(6) =1 1M TOTAL, 256K/PLANE, WD90C31A MEMORY ORGANIZATION 
ADDRESS FROM CPU OR CRTC ADDRESS TO VIDEO 


MEMORY 
BYTE WIDE WORD WIDE DOUBLE WORD WIDE 
CRT/BITBLT CRT/BITBLT 
A(17) | CA(16) A(i7) | CA(15 





amu 
weal 


MA(17) 
MA(16) 
MA(15 
MA(14 


Zz 
a3 
> 
an 
) 
—_h, 


> 

= 

ol 
O}O 
>| > 
Z\4)4 
Ec 

! 











A(13) | CA(11) MA(13 
one ae 
NAG 
MAC) 


TABLE 7-5. WD90C31A MEMORY ORGANIZATION - 1 MBYTES 


NOTES: 
1. A(19:0) are WD90C31A internally modified system Addresses (CPU address + offset address). 


2. CA(17:0) are either CRT Character Address Counter Bits or bitblit generated counter bits. 


3. XRN(5) is Miscellaneous Output Register 3C2H, inverted Bit 5. XRN(5) can be used to 
replace CPU address bits in order to select memory pages in word mode. In IBM compatible 
memory mapping, 3C5.4, Bit 1 = 1 will select XRN(5) to replace CPU address bits. In other 
memory mapping schemes PR1(7,6) # 00, 3C5.4, Bit 1 = 1 and PR16_2 = 1 will select 
XRN(5) to replace address bits. 


4. CA(15) is selected as MA(0) if CRTC Mode Register 17, Bit 5 = 1 in word addressing modes. 


5. PAis the memory plane select bit when DRAM interface is set for 16 bits. 
PA = 0 selects Plane 1,0 
PA = 1 selects Plane 3, 2 


6. MA(17:0) are divided into RAS, CAS addresses as follows: 


For 256K by 4 DRAM or MA 8 
256K by 16 DRAM MA Tie 
(8 
)=> 


For 64K by 16 DRAM MA A(8) 
MA MA 0 


Select ist 64K bank 
Select 2nd 64K bank 
Select 3rd 64K bank 
Select 4th 64K bank 


MA(17, 16) 
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Bits (5:4) - PR1(5,4) Memory Map Select. 


0 0 = IBM VGA mapping. CPU addresses are 
decoded from OAQO000H - OBFFFFH 
from the lowest 1 Mbyte CPU address 
space (depending on 3CF.06 bits 2 and 
3). 


0 1 = First 256 Kbyte in any 1 Mbyte CPU ad- 
dressing space (XOQQ00H - XS8FFFFH) 


1 0 = First 512 Kbyte in any 1 Mbyte CPU ad- 
dressing space (XOOOOOH - X7FFFFH) 


1 1=In any 1Mbyte CPU address space 
(XOO0O00H - XFFFFFH) 


NOTE 
PR34(3C5.14) Bits (3:0) control which 1 
Mbyte of CPU address space the 
WD90C31A maps. See section 7.26. 


Bit 3 - Enable Alternate Address Offset 
Register PROB. 


Bit 2 - Enable 16 bit system interface bus. 


0 = System interface is 8 bits. 
1 = System interface is 16 bits. 


Bit 1 - 16-bit BIOS ROM. 


0 = BIOS ROM access is 8 bits. 
1 = BIOS ROM access is 16 bits. 


A pull-down resistor on MD10 sets this bit to 1 
after power-on reset. This bit can also be set to 1 
by an I/O write cycle only if the CNF(1) = 1. 


Bit 0 - BIOS ROM Map Out. 


0 = The BIOS ROM is available. 
1 = The BIOS ROM is mapped out. 


A pull-down resistor on MDO sets this bit to 1 at 
power-on-reset. 


7.3. PR2- VIDEO SELECT REGISTER, 
READ/WRITE PORT = 3CFH, 
INDEX = OCH 


This register is locked if PR5(2:0) = 5. 


8 | 685 Compaity 


4:3 Character Clock Period 
Control 


Underline/Character Map 
1 Third Clock Select Line 
VCLK2 
a Force VCLK (overrides 
) 


SEQ1 bit 3 
Bit.7 - Enable AT&T/M24 Register and 
Mode. 





O = Disable. 
1 = Enable. 


Bit 6 - 6845 Compatibility. 
0 = VGA or EGA mode. 
1 = Non-VGA (6845) mode. 


Bit 5 - Character Map Select. 
Bits 5 and 2 of this register, and Bit 4 of the At- 


tribute byte, enables character maps from Planes 2 
or 3 to be selected as shown in the table below. 


ATT | PLANE 
(4) | SELECT 





X 2 
X 3 
0 2 
1 3 


The above functions are overridden by setting 
PR15(2) or 3DE(2) to 1, see section 7.12. 
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Bits (4:3) - Character clock period control. 


0 0 = IBM VGA character clock (8 or 9 dots). 


0 1 = 7 dots (used for 132-character text 
mode only). 


10=9Q9dots. 


1 1=6dots if PR17(5) =0 
10 dots if PR17(5) = 1. 


NOTE 
The character clock period control func- 
tions have no effect in graphics modes 
(Graphics Mode always uses eight dots). 


Bit 2 - Underline and character map select. 


Setting this bit to 1 enables underline for all odd 
values of attribute codes, e.g., programming 1 
gives blue underline. It overrides the background 
color function of the Attribute Code Bit 3, which is 
forced to 0. Therefore, only eight choices of back- 
ground colors are selectable. This function allows 
trading background colors for more character 
maps. In conjunction with PR2(5), this bit is also 
decoded to enable character maps from planes 2 
or 3. See the table in PR2(5) for details. 


Bit 1 - Third Clock Select Line. 


This bit is the third clock select line VCLK2 which 
is sent to the external clock chip if CNF(3) = 1. 
When CNF(8) = 0, it locks the internal video clock 
select multiplexer. 


Bit 0 - Force VCLK. 


This bit forces horizontal sync timing clock of the 
CRT Control Register to VCLK. 


Uses VCLK when Sequencer Register 1, Bit 3, is 
set for VCLK/2. This is for compatibility modes 
that require locking the CRT Control Register 
timing parameters. 


7.4 PR3-CRT LOCK CONTROL REGISTER, 


READ/WRITE PORT = 3CFH, 
INDEX = ODH 


This register is locked if PR5(2:0) = 5. 


FUNCTION 
Lock VSYNC Polarity 








2 CRT Control 


Lock Prevention 


Lock Vertical Timing 


Bit 7 - Lock VSYNC Polarity. 















This bit locks VSYNC polarity as programmed at 
Port 3C2H, Bit 7. 


Bit 6 - Lock HSYNC Polarity. 


This bit locks HSYNC polarity as programmed at 
Port 3C2H, Bit 6. 


Bit 5 - Lock Horizontal Timing. 


This bit locks CRT Control Registers of Groups 4 
and 0. It prevents applications software from un- 
locking Group 0 registers by setting 375.11 Bit 7 =0. 


Bit 4 - Bit 9 Control. 


Bit 9 of CRT Controller Start Memory Address 
High Register 375.0C and Bit 9 of Cursor Location 
High 375.0E. This bit corresponds to Character 
Address CA(17). 


Bit 3 - Bit 8 Control. 


Bit 8 of CRT Controller Start Memory Address 
High Register 3?75.0C and Bit 8 of Cursor Location 
High 3?75.0E. This bit corresponds to Character 
Address CA(16). 
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Bit 2 - Cursor Control. 


Cursor Start, Stop, Preset Row Scan and Maxi- 
mum Scan Line Address registers value multiplied 
by two. 


Bit 1 - Lock Prevention. 


1 = Prevents attempts by applications 
software to lock registers of Group 1 by 
setting 375.11, Bit 7 = 1. 


Bit 0 - Lock vertical timing. 


1 = Locks CRTC registers of Groups 2 and 
3. Overrides attempts by applications 
software to unlock Group 2 registers by 
setting 375.11, Bit 7 = 0. 


7.4.1. CRT Controller Register locking 


Register locking is controlled by four bits. They 
are PR3(5,1,0) and 375.11(7) (i.e. IBM Vertical 
Retrace End Register Bit 7 controlled by Index 
register 11). When 375.11 Bit 7 = 1, CRT control- 
ler registers (RO:7) are write-protected per VGA 
definition. For more information on the five groups 
and their locking schemes, refer to the following 
sections. 


¢ Group 0 


These registers are locked if PR3(5) = 1 OR 
325.11(7) = 1. 


375 index 00 - Horizontal Total Characters per 
scan 


375 index 01 - Horizontal Display Enable End 
375 index 02 - Start Horizontal Blanking 

375 index 03 - End Horizontal Blanking 

375 index 04 - Start Horizontal Retrace 

375 index 05 - End Horizontal Retrace 


¢ Group 1 


These registers are locked if PR3(1) = 0 AND 
375.11(7) =1. 


375 index 07 (Bit 6) - Vertical Display Enable 
End Bit 9 


375 index 07 (Bit 1) - Vertical Display Enable 
End Bit 8 


375 index 3E (Bit 1) - Vertical Display Enable 
End Bit 10 
Group 2 


These registers are locked if PR3(0) = 1 OR 
375.11(7) = 1. 


375 index 06 - Vertical Total 

375 index 07 (Bit 7) - Vertical Retrace Start Bit 9 
35 index 07 (Bit 5) - Vertical Total Bit 9 

375 index 07 (Bit 3) - Start Vertical Blank Bit 8 
325 index 07 (Bit 2) - Vertical Retrace Start Bit 8 
375 index 07 (Bit 0) - Vertical Total Bit 8 

375 index 09 (Bit 5) - Start Vertical Blank Bit 9 
375 index 3E (Bit 0) - Vertical Total Bit 10 

375 index 3E (Bit 2) - Vertical Retrace Start Bit 10 
375 index 3E (Bit 3) - Start Vertical Blank Bit 10 


Group 3 

These registers are locked if PR3(0) = 1. 

375 index 10 - Vertical Retrace Start 

375 index 11 [Bits(3:0)] - Vertical Retrace End 
325 index 15 - Start Vertical Blanking 

375 index 16 - End Vertical Blanking 


Group 4 
This register is locked if PR3(5) = 1. 


CRTC Mode Control Register 17 (Bit 2) - 
Selects divide-by-two vertical timing. 
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7.5  PR4- VIDEO CONTROL REGISTER, 
READ/WRITE PORT = 3CFH, 
INDEX = OEH 


The video monitor output contro! register (PR4) 
can be programmed to tristate the CRT display 
control outputs, as well as video data for the 
RAMDAC and memory control outputs. 


This register is locked if PR5(2:0) = 5. 


BIT FUNCTION 


BLANK/Display Enable 
PCLK = VCLK 
Tristate Video Outputs 
4 Tristate Memory Control 
Outputs 
3 Override CGA Enable 
Video Bit 


Lock Internal Palette and 
Overscan Registers 

| 1 | EGA /EGACompatibility = 
a ea 256-color Shift 
Register Control 


Bit 7 - BLANK/Display Enable. 









This bit controls the output signal BLANK. Nor- 
mally in the VGA mode, BLANK is used by the 
external video DAC to generate blanking. 





1 = The BLANK output supplies a display 
enable signal. A choice of two types of 
display enable timings can be selected 
and is determined by PR15(1). 


Bit 6 - Select PCLK equal to VCLK. 


0 = PCLK is either the inverted internal 
video dot clock or half the dot clock fre- 
quency, depending upon the video mode. 


1 = PCLK is always the non-inverted VCLK 
input clock. 





Bit 5 - Tristate Video Outputs. 


1 = Video Outputs VID(7:0), HSYNC, 
VSYNC, and BLANK are tristated. 


Bit 4 - Tristate Memory Control Outputs. 


1 = The memory address bus, MA(8:0), 


and 


all ten DRAM control signals are tristated. 


Bit 3 - Override CGA Enable Video Bit. 


Overrides the CGA Enable Video Bit 3 of mode 
register 3D8H, only in 80 by 25 alpha CGA (Non- 
VGA) mode. Override effectively forces this bit to 


1. Power-on-reset causes no override. 


Bit 2 - Lock Internal Palette and Overscan 


Registers. 


1 = Internal palette and overscan registers 


are locked. 


Bit 1 - EGA compatibility. 


1 = EGA Compatible Mode. Reads are dis- 
abled to all registers which are write- 
only registers in the IBM EGA mode. 


Also, registers at 3COH/3C1H change 


to write-only mode. 


Reading PR5 through PRO is disabled. 
In VGA mode [PR(4) Bit 1 = 0] 3COH 
register is read/write while 3C1H register 
is read only, per the Attribute Controller 


Register’s definitions. 


Bit 0 - Extended Shift Register Control. 


1 = Extended 256-color modes selected 


(IBM Mode 13 is not included). 
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7.6 PR5- GENERAL PURPOSE STATUS 
BITS, READ/WRITE PORT = 3CFH, 
INDEX = OFH 


FUNCTION 
Read CNF(7) Status 
Read CNF(6) Status 
Read CNF(5) Status 
Read CNF(4) Status 


Read CNF(8) Status 
PR4-PRO Unlock 
PR4-PRO Unlock 
PR4-PRO Unlock 





Bits (7:3) - CNF Status 


Bits (7:3) provide a means of reading the read 
only Configuration Register (CNF), Status Bits 
(8:4). CNF(8:4) are described in section 9.0. 


Bit 7 - CNF(7) General Purpose Status. 
Bit 6 - CNF(6) General Purpose Status. 
Bit 5 - CNF(5) General Purpose Status. 
Bit 4 - CNF(4) General Purpose Status. 
Bit 3 - CNF(8) Analog/TTL Display Status. 


Bits (2:0) - PR4-PRO. 


These are read/write bits and are cleared by 
reset. They provide lock and unlock capability for 
PR registers PR4 through PRO. The PR4 through 
PRO registers are unlocked when "X5H" is written 
to PR5. They remain unlocked until any other 
value is written to PRS5. 


Setting PR4 Bit 1 to 1, read protects registers PR5 
through PRO. 


PR5 PR4-PRO 
210 


OX X Write protected 









Write protected 
Write protected 
Write enabled 


7.7 PR10-UNLOCK PR1A, PR(17:11) 
READ/WRITE PORT = 3?5H, INDEX = 29H 


PR10 is a read/write register and is cleared by 
reset. PR10 controls access to registers PR1A 
and PR17 through PR11. 


Bits (7, 3) enable read operations for PR1A and 
PR17 through PR11. 


Bits (6:4) are reserved, must be set to 0. 


Bits (2:0) enable write operations for PR1A and 
PR17 through PR11. 


BIT FUNCTION 


PRi1A, PR(17:11) - Read 
Enable Bit 1 


Reserved, must be set to 
0 


PR1A, PR(17:11) - Read 
Enable Bit 0 

PR1A, PR(17:11) - Write 
Enable 










Bits 7, 3 - PR1A, PR(17:11) Read Enable. 


BIT7 | BIT3 | PR1A, PR(17:11) 


0 X Read protected, 
Xx | read back data 
Fe ae Or Read Enabled 


FFH 
Bits 6:4 - 









Reserved, must be set to 0. 


Bits 2:0 - PR1A, PR(17:11) Write Enable. 


PR10 PR1A, PR(17:11) 
210 
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7.8  PR11- EGA SWITCHES, READ/WRITE 
PORT = 3?75H, INDEX = 2AH 


The EGA switch configuration details are stored in 
register PR11. 


This register is locked if PR10(2:0) # 5. 









BIT FUNCTION 
EGASW4/General Purpose 
EGASW3/General Purpose 


EGASW2/General Purpose 
EGASW1/General Purpose 


3 EGA Emulation on Analog 
Display 
Lock Clock Select 


1 Lock Graphics and Sequen- 
cer Screen Control 


oe Lock 8/9 Character Clock 


Bits (7:4) - EGA Configuration Switches 
SW4-SW1. 























These read/write bits from corresponding memory 
data bus pins MD(15:12) are latched internally at 
power-on-reset with either pull-up or pull-down ex- 
ternal resistors. Pulling-up MD(15:12) causes 
PR11(7:4) to be latched high. These bits can be 
read from Bit 4 of the Input Status Register at Port 
3C2H if the EGA compatibility bit PR4(1) = 1. 
Selection of the bit to be read is determined by 
Bits 3 and 2 of the Miscellaneous Output Register 
at Port 3C2H, as follows. 


WRITE 
3C2H 
Bit 3 Bit 2 


0 0 
0 

1 
1 


PR11(7) = EGA SW4 


(7) 
1 | PR11(6) = EGA SW3 
0 | PR11(5) =EGASW2 
1 | PR11(4) = EGA SW1 





These bits may be used as general purpose 
scratch bits. 


Bit 3 - Select EGA Emulation on a PS/2 
(VGA-compatible, analog) display. 


This is a read/write bit and is set to zero at power- 
on-reset. 


Bit 2 - Lock Clock Select. 


This bit locks the internal video clock select multi- 
plexer and disables loading of an external clock 
chip through VCLK1. 


This is a read/write bit and is set to zero at power- 
on-reset. 


Bit 1 - Lock Graphics Controller/Sequencer 
Screen Control. 


Setting this bit to 1 prevents modification of the 
following bits in the Graphics Controller as well as 
the Sequencer: 


3CF.05 bits (6:5) 
3C5.01 bits (5:2) 
3C5.03 bits (5:0) 


Although the internal functions selected by the 
graphics controller and sequencer bits are locked 
by setting PR11 Bit 1 to 1, they appear unlocked 
to the system processor during read operation. 


Graphics Controller 
Sequencer 
Sequencer 


This is a read/write bit and is set to zero at power- 
on-reset. 


Bit 0 - Lock 8/9 Dots. 


Setting this bit to 1 prevents modification of the 
Clocking Mode Sequencer Register 3C5.01, Bit 0. 


1 = Eight and nine dot wide character timing 
is locked. Register 3C5H.01 Bit 0 still 
appears unlocked to the system proces- 
sor during read operations. 


This is a read/write bit and is set to zero at power- 
on-reset. 





9/3/92 


17-67 





WD9I0C3TA 


PR REGISTERS 





7.9 PR12- SCRATCH PAD, READ/WRITE 
PORT = 3?5H, INDEX = 2BH 


This register is locked if PR10(2:0) # 5. 


BIT FUNCTION 
Scratch Pad Bits (7:0) 


The data in this register is unaffected by hardware 
reset and undefined at power-up. 


7.10 PR13 - INTERLACE H/2 START, 
READ/WRITE PORT = 375H, 
INDEX = 2CH 


This register is locked if PR10(2:0) # 5. 


BIT FUNCTION 
Interlaced H/2 Start 


The data in this register is unaffected by hardware 
reset and undefined at power-up. 


In interlaced operations, this register defines the 
Starting horizontal character count at which verti- 
cal timing is clocked on alternate fields. Interlaced 
operation is enabled by setting PR14(5) to 1. 


All other standard non-interlaced modes are unaf- 
fected by the contents of this register. This register 
must be programmed with a value derived from 
the values chosen to be programmed into the 
Horizontal Retrace Start Register (375.04) and 
Horizontal Total Register (375.00): 


PR13(7:0) = [HORIZONTAL RETRACE START] - 
[(HORIZONTAL TOTAL + 5)/2] + HRD 


NOTE 
In the above expression, HRD = Horizon- 
tal Retrace Delay, determined by Bits 6 
and 5 of the Horizontal Retrace End 
Register (375.05). 


7.11 PR14- INTERLACE H/2 END, 
READ/WRITE PORT = 3?5H, 
INDEX = 2DH 


This register is locked if PR10(2:0) # 5. 


FUNCTION 
Enable IRQ 


Sa Vertical Double Scan for 
EGA on PS/2 Display 


Enable Interlaced Mode 
Interlaced H/2 End 





Bits 7 through 5 are set to 0 by reset. 


Bits 4 through 0 are unaffected by hardware reset 
and undefined at power-up. 


Bit 7 - Enable IRQ. 


This bit may be set to enable CRT interrupts to be 
generated when configured for AT BUS operation, 
allowing EGA compatibility support for interrupt- 
driven EGA applications. For VGA operation with 
an AT BUS, interrupts are not used and this bit 
should be set to 0. This bit should not be set to 1 
in Micro Channel operation. 


0 = IRQ disabled. Used in VGA operations 
with an AT bus and Micro Channel 
operations. 


1 = IRQ enabled. 


Bit 6 - Vertical Double Scan. 


This bit should be set to 1 when emulating EGA 
on PS/2 display. Setting this bit to 1 causes the 
CRIC’s Vertical Displayed Line Counter and Row 
Scan Counter to be clocked by divide-by-two 
horizontal timing, if vertical sync polarity (8C2H Bit 
7 = 0) is programmed to be positive. Therefore, 
the relationship between the actual number of 
lines displayed [N] and the data [n] programmed 
into the Vertical Display Enable End register is: 
N=2(n+1). 


Likewise, the relationship between the actual 
number of scan. lines per character row [N] and 
the data [n] programmed in the maximum Scan 
Line register holds true. 
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Bit 5 - Interlaced Mode. 


The interlaced mode can be used in those video 
modes in which the data programmed into the 
Maximum Scan Line Address register [375.09] = 
OXX00000. Line compare and double scan are 
not supported. 


O = Interlaced Mode not enabled. 
1 = Interlaced Mode is enabled. 


Bits (4:0) - Interlaced H/2 End Bits (4:0). 


Add the contents of the Interlaced H/2 Start 
Register PR13 to the horizontal sync width (same 
as defined by 3X5.04,05). Program the five LSBs 
of the sum into these bit locations. 


7.12 PR15- MISCELLANEOUS CONTROL 1, 
READ/WRITE PORT = 3?5H, 
INDEX = 2EH 


This register is locked if PR10(2:0) z 5. 


BIT FUNCTION 
Read 46E8H Enable 


| 6 High VCLK 
VCLK1,VCLK2 Latched 


Outputs 


VCLK = MCLK 


3 8514/A Interlaced Com- 
patibility 


Enable Page Mode 
Select Display Enable 
i er | Disable Border 


Bit 7- Enable Reading Port 46E8H. 













This bit is functional only if AT BUS architecture 
[CNF(2)=1] is selected. 


1 = I/O Port 46E8H may be read, regardless 
of the state of its own Bits 4 and 3 and 
of Port 102H, Bit 0 (sleep bit). Only 
Bits(4:0) of Port 46E8H are readable, 
Bits (7:5) are 0. 


Bit 6 - High VCLK. 


This bit should be set to 1 when (MCLK in MHz / 
VCLK in MHz) equals 1.5, or in an extended 256- 
color mode. 





1 = Memory timing is adjusted to allow use 
of a video clock (VCLK) frequency which 
is much higher than the memory clock 
(MCLK) frequency. 


Bit 5 - Latched VCLK1 and VCLK2. 


This bit is used only if CNF(3) = 1, which con- 
figures the VCLK1 and VCLK2 pins as outputs. 


1 = Outputs VCLK2 and VCLK1 are equal to 
Bits 3 and 2 of |/O write register (Miscel- 
laneous Output Register) at Port 3C2H, 
respectively. 


Bit 4 - Select MCLK as Video Clock. 


1 = MCLK input is selected for the source of 
all video timing. The other three VCLK 
inputs can not be selected when this bit 
is set. 


Bit 3 - Interlaced Compatibility. 


This bit should be set to 1 only if interlaced mode 
is selected (See PR14) and exact timing emulation 
of the IBM 8514/A’s interlaced video timing is re- 
quired. 


1 = Vertical sync is generated from the trail- 
ing edge of non-skewed horizontal sync 
instead of the leading edge, as generat- 
ed for VGA timing. Also, two VCLK 
delays are removed from the default 
VGA video dot path delay chain. 
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Bit 2 - Select Page Mode Addressing. 


Graphics Modes automatically use Page Mode 
addressing. 


Alpha modes require this bit to be set to 1 for 
screen refresh memory read cycles to use Page 
Mode addressing. Setting this bit to 1 in any 
Alpha Mode overrides the character map select 
functions of PR2(2) and PR2(5). 


Page Mode addressing requires less time than 
RAS-CAS addressing, therefore, selecting Page 
Mode addressing increases the bandwidth for the 
CPU to access video memory by 30-40%. 


PR15(2) should be set to 1 if 132 Character Mode 
timing is selected (see description of PR2). 


When PR15(2) is set to 1, it redefines the Charac- 
ter Map Select Register (8C5.03). One of eight 8K 
memory segments containing a pair of maps in 
Plane 3 or Plane 2 is addressed by Bits(2:0) of 
this register while the map selection is determined 
by Bits(4:3). A pair of adjacent 8K character maps 
in Planes 3 and 2, (adjacent in the sense that they 
have the same addressing) may be selected by 
Bit 3 of the Attribute Code. 


The Character Attribute Bit 3 (See section 5.6.4), 
in conjunction with Bits 4 and 3 of the Character 
Map Select Register (8C5.03), determine a char- 
acter map from either Plane 3 or Plane 2 as 


shown by the table below. 
PR15 |3C5.03/3C5.03; ATT | PLANE 
(2) (4) (3) (3) | SELECT 
2 


1 
] 
1 
1 
1 
1 





The above Character Map Select func- 
tions override the functions of PR2(5) 
and PR2(2). 


This bit must be set to 1 before loading the char- 
acter maps into the video DRAM, because the 
addressing of the page mode character maps dif- 
fers from the addressing of the default, non-page 
mode. However, setting this bit to 1, internally 
redirects all necessary addressing to make load- 
ing the character maps the same, whether in page 
mode or non-page mode. 7 


Bit 1 - Display Enable Timing Select. 


This bit is used to select between two types of 
display enable timings available at output pin 
BLANK if PR4(7) = 1. If PR4(7) = 0, this bit has 
no effect. 


0 = BLANK supplies Pre-Display Enable. 
Pre-Display Enable timing precedes ac- 
tive video by one dot clock. 


1 = BLANK supplies Display Enable. The dis- 
play enable timing coincides with active 
video timing. 


Bit 0 - Disable Border. 


Setting this bit to 1 forces the video outputs to 0 
during the interval when border (overscan) color 
would be active. 
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7.13 PR16- MISCELLANEOUS CONTROL 2, 
READ/WRITE PORT = 3?5H, 
INDEX = 2FH 


This register is locked if PR10(2:0) + 5. 
BIT FUNCTION 


7 External Register 46E8H 
Lock 
CRT Control Address 
Count Width Bit 1 

5 CRT Control Address 
Count Width Bit 0 

4 CRT Control Address 
Counter Offset Bit 1 

3 CRT Control Address 
Counter Offset Bit 0 

Enable Odd/Even Page 

Bit 


VGA Mapping Enable 





Lock RAMDAC Write 
Strobe 


Bit 7 - Lock External 46E8H Register. 


Setting this bit to 1 causes EBROM output to be 
forced high (inactive) during I/O writes to Port 
46E8H. 


Bits (6:5) - CRT Control Address Counter 
Width. 


Power-on-reset clears these bits to 0. These two 
bits determine the modulus of the CRT Control- 
ler’s address counter, allowing its count width to 
be limited to 64K or 128K locations (Byte, Word, 
Double word). These bits may be used in virtual 
VGA applications containing 512KB or 1024KB of 
video memory, in which CRT Controller is limited 
to only 64K or 128K locations. Bit PR16(6) should 
be set 1 to ensure VGA and EGA compatible 
operation of the address counter, limited to 64K 
locations. 


COUNT WIDTH 
00 = 256KB 
01= 128K 
1X = 64K 


Bits (4:3) - CRT Control Address Counter 
Offset. 


Bits 4 and 3 are summed with the CRT Control- 
ler's Address Counter Bits CA(17) and CA(16), 
respectively, and the two-bit result defines the 
starting location of the displayed video buffer at 
one of the four 64K boundaries. 


Bit 2 - Enable Page Bit for Odd/Even. 


This bit affects addressing of memory by the sys- 
tem processor, if chain 2 (Odd/Even) has been 
selected by setting 3CF.06(1) to 1, setting 
3C5.04(1) to 1, selecting extended memory and 
setting 3C5.04(3) to 0 to deselect chain 4 ad- 
dressing. It enables the Page Bit for Odd/Even 
[8C2(5)] to select between two pages of memory, 
by controlling video RAM address 0, regardless of 
the Memory Size Bits PR1(7:6). 


Bit 1 - VGA Memory Mapping. 


Setting this bit to 1 selects 256 Kbyte IBM VGA 
Mapping, regardless of the Memory Size Bits 
PR1(7°6). 


Bit 0 - Lock RAMDAC Write Strobe 
(3C6H - 3C9H). 


O = Normal operation. 


1 = Output WPLT to be forced to 1, disabling 
I/O writes to the video DAC registers. 
The DAC state register, located inside 
the WD90C31A, is also protected from 
the modification but may still be read at 
the Port 3C7H. 
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7.14 PR17-MISCELLANEOUS CONTROL 3, 
READ/WRITE PORT = 3?5H, 
INDEX = 30H 


This register is locked if PR10(2:0) # 5. 


sanction 


Character Clock Period 
Select 


) 


Enable 64K BIOS ROM 
Hercules Compatibility 








Map Out 2K Of BIOS 
ROM 


Bit 5: - Character Clock Period Select. 


Bits (7:6) 
Reserved. 


To enable PR17 Bit 5, PR2 (8CF.0C) Bits 4:3 must 
equal 11. When Bit 5 is not enabled, it has no effect. 


0 = Six-dot font is selected. 
1 = Ten-dot font is selected. 


Bit 4- PCLK = Yolo, 


1 = Forces PCLK = Y““/2. This control is 
useful for interface with high color RAM- 
DAC as follows: 


16 bits of color information per pixel 


eee | arenes | ea eee 





Bit (3) - Map Out 4K of BIOS ROM. 


1 = Disables access of the BIOS ROM in the 
system address range C600:0H through 
C6FF:FH. 


Power-on-reset sets this bit to 0. 


Bit 2 - Enable 64K BIOS ROM. 


1 = Enables access of the BIOS ROM in the 
system address range C000:0H through 
CFFF:FH. 


Power-on-reset sets this bit to 0. 
ra 2 


Bit 1 - Hercules Compatibility. 


1 = Locks Hercules compatibility register 
(I/O Port 3BFH). 


Power-on-reset sets this bit to 0. 


Bit 0 - Map Out 2K of BIOS ROM. 


1 = Disables access of the BIOS ROM in the 
system address range C600:0H through 
C67F:FH. 


Power-on-reset sets this bit to 0. 


7.15 PR18-CRTC VERTICAL TIMING OVER- 
FLOW, READ/WRITE PORT = 3?5H, 
INDEX = 3EH 


These bits, combined with other vertical timing 
overflow bits in CRT Control, constitutes an 11-bit 
vertical timing control. These bits are set to zero at 
power-on-reset. 


BIT 


@1 | Vertical Display Enable 
End Bit 10 
Vertical Total Bit 10 


® The bit is locked if PR3(0) 
OR the 375 Index 11 Bit 7 
@ The bit is locked if PR3(1) 

AND the 375 Index 11 Bit 



























= 1 
= 1 
= 0 
7=1 
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7.16 PR19- VIDEO SIGNATURE ANALYZER 
CONTROL READ/WRITE PORT = 3?5H, 
INDEX = 3FH 


BIT FUNCTION 


Reserved 


2) Sra Rad Ea 
(2 | Enabe Video input 
aa 
on 













PreLoad Control 
Enable/Status Bits 





Bits (7:4) 
Reserved 


Bit 3 - Signature Read Enable. 


1 = Read signature analyzer results from 
3?5H, Index 20 and 21. 


Bit 2 - Enable Video Input. 


This bit is used for self-test. 
0 = Enable video input for signature analyzer. 


1 = Self-testing. The video input to the signa- 
ture analyzer is disabled. 


Bit 1 - Preload Control. 


0 = The Signature Analyzer Result Register 
(375, Index 20 and 21) is preloaded with 
0001H. 


1 = Normal operation. 


Bit 0 - Enable/Status Bits. 
Writing to this bit: 


1 = Enables the signature analyzer to collect 
signature on video input. 


Reading this bit: 


Indicates the status of the signature analyzer col- 
lecting the signature on video input. 


0 = Finished (or not enabled). 
1 = Busy. 


7.17 PR1A-SHADOW REGISTER CON- 
TROL, READ/WRITE PORT = 3?5H, 
INDEX = 3DH 


This register is locked if PR10(2:0) # 5. 
Bits (7:4) 
Reserved. 


Bits 3 - |/O Read Select. 


0 = Select actual CRT Control registers for 
read. 


1 = Select shadow CRT Control registers for 
read. 


Bits (2:0) - Shadow Lock. 


101 = Locks all the shadowed register bits. 
This lock overrides any locks. Refer to 
the Shadow Register description for 
details. 


7.18 PR20-UNLOCK SEQUENCER EX- 
TENDED REGISTERS, READ/WRITE 
PORT 3C5H, INDEX = 6H, 

(RESET STATE = LOCKED) 


A value of X1X01XXX must be written to this 
register to allow Read or Write operations of the 
Sequencer Extended Registers. When the ex- 
tended registers are locked, the Sequencer Index 
is read as three bits. When unlocked, the Se- 
quencer Index reads as six bits. 
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7.19 PR21 -DISPLAY CONFIGURATION 
STATUS AND SCRATCH PAD BITS 
REGISTER, BITS 7:4 READ/WRITE 
BITS 3:0, READ ONLY PORT 3C5H, 
INDEX = 7H 


This register is locked if PR20(6, 4, 3) # 101. 


This register provides a convenient location for 
determining the current state of the VGA con- 
figuration. This information is required for many 
BIOS cails. 


FUNCTION 


Status of 3C2 Bit 0 
Status of PR2 Bit 6 
Status of PR4 Bit 1 
Status of PR5 Bit 3 





Bits (7:4) - Scratch Pad Bits. 


These read/write bits serve as a scratch pad for 
any BIOS status data that may need to be saved. 
These bits are preset to 1111 at reset. 


Bit 3 - Status of 3C2H Bit 0. 


This read only bit represents the setting of the I/O 
address select bit in the Miscellaneous Output 
Register. 


0 = MDA (3Bx) addresses have been selected. 
1 = CGA (3Dx) addresses have been selected. 


Bit 2 - Status of PR2 Bit 6. 


This read only bit represents the setting of the 
VGA/6845 select bit in PR2 (3CFH Index CH). 


0 = VGA or EGA compatibility has been 
selected. 


1 = 6845 compatibility has been selected. 


Bit 1 - Status of PR4 Bit 1. 


This read only bit represents the setting of the 
VGA/EGA select bit in PR4 (8CFH Index Eb). 


0 = VGA was selected. 
1 = EGA compatibility has been selected. 


Bit 0 - Status of PR5 Bit 3. 
This read only bit represents the setting of the 
Analog/TTL status bit in PR5 (8CFH Index FH). 

0 = An analog monitor was selected. 


1 = ATTL-type monitor was selected. 


7.20 PR22 -SCRATCH PAD REGISTER, 
READ/WRITE PORT = 3C5H, 
INDEX = 8H 

Bits (7:0) 

Scratch pad bits. 


7.21 PR23 -SCRATCH PAD REGISTER, 
READ/WRITE PORT = 3C5H, 
INDEX = 9H 


Bits (7:0) 
Scratch pad bits. 


7.22 PR30 - MEMORY INTERFACE, WRITE 
BUFFER AND FIFO CONTROL 
REGISTER, READ/WRITE PORT = 3C5H, 
INDEX 10H 


This register is locked if PR20(6, 4, 3) # 101. 


This register controls display memory data width 
and its bandwidth. All bits are reset to zero at 
power-on-reset. 


FUNCTION 


Disable 16-bit CPU In- 


terface for Unchain 








17-74 


9/3/92 ~ 
7 


PR REGISTERS 


WD9I0C31A 





Bits (7:6) - Write Buffer Control. 


Bits 7 and 6 determine the depth of the write buffer. 


PR31 Bit 2 must be set to 1 for these two bits to 


have any effect. 
WRITE BUFFER LEVEL 
0 0 = One level deep. 
0 1 = Two levels deep. 
1 0 = Three levels deep. 
1 1 = Four levels deep. 


Bit 5 - Memory Data Path. 


0 = The display memory data path is 32-bits 
wide. 


1 = The display memory data path is 16-bits 
wide. 
Bit 4 - Disable Unchained Mode. 


0 = Normal conditions. 


1 = 16-bit interface, unchained mode is dis- 
abled. This is for debug only. 


Bit 3 - Two-level FIFO. 


0 = The FIFO is four or eight levels deep, 
depending on Bit 2 of this register. 


1 = The FIFO is two levels deep, regardless 
of Bit 2. 


Bit 2 - Four or Eight-Level FIFO. 


0 = FIFO set to eight levels deep. 
1 = FIFO set to four levels deep. 


Bits (1:0) - Display FIFO Control. 


These two bits can be used to adjust the display 
memory bandwidth. In general, to accommodate 
most applications, it is recommended that these 
two bits be set to 01. These bits have no effect in 
any text mode. They are locked into 00 internally 
when a text mode is set. 


FIFO requests for memory 
cycle when FIFO is: 


0 0 = One level empty 
0 1 = Two levels empty 
1 0 = Three levels empty 


1 1 = Four levels empty 


7.23. PR31-SYSTEM INTERFACE CON- 
TROL, READ/WRITE PORT = 3C5H, 
INDEX = 11H, RESET STATE = 00 


This register is locked if PR20(6, 4, 3) # 101. 

This register provides the control bits for the sys- 
tem interface. This register should be set during 
the post initialization routines of the VGA BIOS. 
The reset state is 100% IBM VGA compatible. Bit 


7 is used during some of the enhanced display 
modes. 


FUNCTION 
Read/Write Offset Enable 


Turbo Mode for Blanked 
Lines 


5 Turbo Mode for Text 

4 CPU Read RDY Release 
Control 1 

3 CPU Read RDY Release 
Control 0 


Enable Write Buffer 


1 Enable 16-bit I/O Attribute 
Controller 
_ Enable 16-bit I/O Opera- 



























and Graphics Controller 








tion on CRTC, Sequencer 
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Bit 7 - Read/Write Offset Enable. 


0 = Normal (Refer to PROA and PROB defini- 
tions). 


1 = During read cycles, the offset register 
PRO-A, is added to the CPU address. 
During write cycles PRO-B is added to 
the CPU address. 


Bit 6 - Turbo Mode for Blanked Lines. 


O = Normal. 


1 = System performance is improved by 
10% by removing extra screen refresh 
memory cycles on vertical blank. 


Bit 5 - Turbo Mode for Text. 


0 = Normal. 


1 = Improved text mode performance. 


Bits (4:3) - CPU Read lIOCHRDY Release 
Controls 1,0. 


These two bits select the IOCHRDY timing for 
CPU reads. To improve performance of systems 
with a slower bus clock, IOCHRDY may be asserted 
earlier. Data will be ready following IOCHRDY no 
sooner than the time selected by bits (4:3). 


0 0 = 40 ns. (Power-on-reset condition). 
01=40ns. plus 1 MCLK. 
10=40ns. plus 2 MCLKs. 

1 1=40ns. minus 1MCLK. 


For 10 MHz or slower systems, the 01 setting is 
recommended. For 12 MHz or faster systems, the 
11 setting is recommended. 


Bit 2 - Enable Write Buffer. 


0 = Write buffer disabled. 


1 = Write buffer is enabled. This greatly 
reduces the number of wait states for 
CPU writes to display memory. 


Bit 1 - Enable 16-bit I/O Attribute Controller. 


If Bit 1 and Bit 0 are both set to 1, the Attribute 
Controller (3COH/3C1H) is configured for 16-bit 
access. The index is at 3COH while the data is at 
3C1H and the address toggle is disabled for 16-bit 
reads or writes. The address toggle functions in 
the standard way for eight-bit cycles. -lIOCS16 is 
asserted for all cycles to 3COH or 3C1H. 





Bit 0 - Enable 16-bit I/O Operations. 


0 = The VGA 1/O is eight-bits. 


1 = Enables 16-bit access to the CRTC 
(3?4H/375H), Sequencer (8C4H/3C5H) 
and Graphics Controller (3CEH/3CFH). 
The output |OCS16 will be active for any 
I/O read or write to these addresses. 





7.24 PR32-MISCELLANEOUS CONTROL 4, 
READ/WRITE PORT = 3C5H, 
INDEX = 12H, RESET STATE = 00 


This register is locked if PR20(6, 4, 3) # 101. 
This register provides control for several different 
features. Some of these features help to support 


Genlock of the WD90C31A to another display 
controller for overlay. 


FUNCTION 
Enable External Sync 


isable Cursor Blink 
SRi Function Select 
SR1 Control 
USRO Function Select 
USRO Control 


Allow Read Back in Back- 
ward compatible Modes 


Force Standard CPU Ad- 
dressing in 132-column 
Mode 
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Bit 7 - Enable External Sync Mode. 


0 = Normal operation mode. 


1 = EXVID is configured to input external 
Horizontal Sync and EXPCLK inputs ex- 
ternal Vertical Sync. The external 
HSYNC signal also synchronizes the 
character clock timing. In this configura- 
tion, EXVID and EXPCLK do not control 
the VID7:0 and PCLK output buffers, but 
they are used to genlock the 








WD90C31A to another display controller. 


Bit 6 - Disable Cursor Blink. 


0 = Blink enabled. 


1 = The text cursor blink is disabled and the 
cursor remains on. This option can be 
used when cursor blink is not desired. 


Bit 5 - USR1 Function Select. 


0 = The USR1 output represents the state of 
Bit 4. This can be used to control new 
features added by the system board 
designer. 


1 = Reserved. 


Bit 4 - USR1 Control. 
Controls the USR1 output when selected by Bit 5. 


Bit 3 - USRO Function Select. 


0 = The USRO output represents the state of 
Bit 2. This can be used to control new 
features added by the system board 
designer. 


1 = Reserved. 


Bit 2 - USRO Control. 


Controls the USRO output when selected by Bit 3. 


Bit 1 - Read in Backward Compatible 
Modes. 


0 = Registers that are not normally readable 
in backward compatibility modes may 
not be read. 


1 = Registers that are not normally readable 
in backward compatibility modes may be 
read. 


This option may be used either as a test feature or 
by the BIOS during mode changes. 


Bit 0 - 132-Column Mode. 


1 = The special CPU address mapping for 
page mode font access in 132-column 
text is set for standard mapping without 
disturbing the display. This is used only 
for special virtual VGA applications. 


7.25 PR33- DRAM TIMING AND ZERO WAIT 
STATE CONTROL, READ/WRITE 
PORT = 3C5H, INDEX = 13H 


This register is locked if PR20(6, 4, 3) # 101. 


Bits (7:6) - OWS Control. 


These two bits control the operation of the OWS 
output pin. OWS is disabled if PR31 bit 2 = 0 
(Write Buffer is off). 


00 = OWS = O if the internal write buffer is 
ready. 


0 1 = OWS = 0 if the internal write buffer is 
ready and the memory address is 
decoded. 


10 = OWS = O if the internal write buffer is 
ready and the memory address is 
decoded and MWR = 0. 


11 = OWS = O if the condition in 10 is true or 
I/O write to the WD90C31A is occurring. 





Bit 5 
Reserved 
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Bits (4:3) - CAS Timing. 
These two bits control the CAS timing. 


00 =CAS cycle is 2 MCLKs. 
CAS low is 1 MCLK + (4~7) ns. 
CAS high is 1 MCLK - (4~7) ns. 


01 =CAS cycle is 2 MCLKs. 
CAS low is 1 MCLK + (8~14) ns. 
CAS high is 1 MCLK - (8~14) ns. 


10 =CAS cycle is 2 MCLKs. 
CAS low is 1.5 MCLKs. 
CAS high is 0.5 MCLKs. 


1 1 = Reserved. 


Bit 2 - CAS After RAS Timing. 


0 = CAS cycle starts 2.5 MCLKs after RAS low. 
1 = CAS cycle starts 1.5 MCLKs after RAS low. 


Bits (1:0) - RAS Precharge. 
These two bits control RAS precharge. Refer to 
DRAM timing adjustments in Section 19.0. 


0 0 = RAS high is 2-1/2 MCLKs plus a 4:7 ns. 
delay. 





7.26 PR34- VIDEO MEMORY MAPPING, 
READ/WRITE PORT = 3C5H, 
INDEX = 14H 


This register is locked if PR20(6, 4, 3) # 101. 


Bits (7:4) 
7:6 Reserved, 5:4 reserved for Driver usage. 


Bits (3:0) - Video Memory Mapping. 


These four bits are compared with the CPU ad- 
dress A(23:20) as part of the video memory ad- 
dress decoding. This allows the VGA to be 
mapped into any 1 Mbyte CPU memory space. 
This register does not affect the EBROM and 
ROM16 decoding. EBROM and ROM16 are still 
decoded at A(23:20) = OH. Used with the correct 
setting of PR1, Bits 5 and 4, this register supports 
virtual VGA applications. 











These four bits are set to 0 at power-on-reset. 


7.27 PR35 - RESERVED, READ/WRITE 
PORT = 3C5H, INDEX = 15H 


This register is locked if PR20(6, 4, 3) # 101. 





0 1 = RAS high is 3 MCLKs wide. as 7 
—— eserved. 
1 0 = RAS high is 2 MCLKs wide. : 
1 1 = RAS high is 2-1/2 MCLKs. 
a B 
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8.0 INTERNAL I/O PORTS 


8.1 AT MODE SETUP, ENABLE, WRITE 
ONLY PORT 46E8H (ALSO AT PORT 
56E8H, 66E8H, 76E8H) 








Bits (7:5) 
Unused. 


Bit 4 - Setup. 


This bit puts the WD90C31A into Setup mode 
where only I/O Port 102H is accessible. 


Bit 3 - Enable I/O and Memory Accesses. 


This bit enables I/O and memory accesses. 


Bits (2:0) - BIOS ROM Page Select. 


On |/O accesses to Port 46E8H, EBROM be- 
comes I/O write strobe for external implementa- 
tion of BIOS ROM page mapping. Bits (2:0) are 
latched data bits and define 4K pages on BIOS 
ROM. The external mapping logic affects the 
three most significant bits of address applied to 
the BIOS ROM. The ROM therefore, appears to 
consist of eight, 4K pages. External circuitry is 
required to implement the BIOS ROM page selec- 
tion using these bits (D2:D0). The WD90C31A 
also provides Port 3C3H as an alternative to Port 
46E8H. If a pull-down resistor is connected to 
MD9 during power-on-reset [CNF(9) = 0], Port 
3C3H is decoded instead of Port 46E8H to sup- 
port the same functions as described above. 
Otherwise, Port 46E8H is selected and decoded. 


WD9I0C3TA 


8.2. SETUP MODE VIDEO ENABLE (AT AND 
MICRO CHANNEL MODES) 
READ/WRITE PORT = 102H 
(XXXX XXXX XXXX X010B) 


FUNCTION 
ee Wakeup VGA 


Bits (7:1) 
Unused. 







Bit 0 - Wakeup VGA. 


Wakeup VGA for I/O and Memory Accesses. Only 
the lower three address bits are decoded for this 
port and the WD90C31A must be in Setup mode. 
VGA Enable Sleep bit or Programmable Option 
Select (POS) Register 102H Bit 0 is used to 
awaken the WD90C31A after power on in the 
MCA and AT mode. To enter the Setup mode in 
AT bus applications, Bit 4 of the partially decoded 
internal I/O Port 46E8H is set to 1 before access- 
ing the I/O Port 102H. In MCA mode, _ the 
WD90C31A is in Setup mode and Port 102H can 
be accessed when the VGA setup (EIO) signal pin 
is active low. 
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9.0 CONFIGURATION REGISTER BITS 


CNF(18:0) 


Memory Data Lines (18:0) [MD(18:0)] are used to 
input configuration data [CNF(18:0)] at power-on- 
reset (RST) by pull-up or pull-down resistors. This 
configuration data sets the bits in internal 
registers. CNF(15:12), CNF(10) and CNF(O) can 
also be changed by software, while all others are 
in non-writable registers. The non-writable bits set 
features such as bus type which are not changed 
after power-on. All MD(18:0) are internally pulled 
up by 50 ohm resistors. 


FUNCTION 
Enable ROM16 as EXBLANK input 
a eer 
11 
10 

‘4 
1 











i1___[/A25- A20 Gonnecton Sect 
[10 | Disable ROMS adress decode 
re |aBEBHBCaH Select 
(8 [Display Sas 
"| ROM Configuration 
(0 | BIOSROM Mapping 


CNF(18) - ROM16 As EXBLANK input. 








0 = A 4.7K pull-down resistor on Pin MD18. 
ROM{16 is configured as EXBLANK 
input. 





1 = No pull-down resistor, the internal pull- 
up sets CNF(18) to 1. Normal ROM16 
operation. ROM16 is an output. 





CNF(16) - 64K By 16 Or 256K By 4 DRAM 
Select. 


0 = A 4.7K pull-down resistor on pin MD16 
sets the WD90C31A to interface with a 
64K by 16 DRAM. 


1 = No pull-down resistor. The internal pull- 
up sets WD90C31A to interface with a 
256K by 4 or 256K by 16 DRAM. 


CONFIGURATION REGISTER BITS CNF(18:0) 


CNF(15:12) - EGA Configuration Switches 
SW4-SW1. 


No external pull-down resistors on MD(15:12) 
causes PR11(7:4) to be latched high. Pulling 
down MD(15:12) causes these bits to be latched 
low. 


PR11(7:4) are writable bits. These bits can be 
read as Bit 4 of Port 3C2H (as on a standard 
EGA) if the EGA compatibility bit [PR4(1)] has 
been set to 1. Selection of which bit to read is 
determined by Bits 3 and 2 of the Miscellaneous 
Output Register 3C2H, as follows. 


WRITE | READ 
Lo ee PR11(7) [= EGA SW4] 
0 [4 | PRI) T= EGA sw 
=a 
—- 


[ = 
6) [=E 
0 PRIN) [= EGA Swa]_ 
1 
CNF(11) - 


















PR11(4) [= EGA SWI] 


Reserved. Pin has an internal pull-up resistor. Do 
not use an external pull-down resistor. 


CNF(10) - Disable ROM16 Address Decode. 


0 = The internal pull-up sets CNF(10) = 
PR1(1) = 0. To enable the 16-bit BIOS, 
PR1(1) must be set to 1 by writing to 
Port 3CFH, Index OBH Bit 1 and, at the 
same time, CNF(1) must be 1. 

1 = A 4.7K pull-down on Pin MD10 sets 
CNF(10) = PR1(1) = 1. Upon power-up, 
the pin ROM16 is enabled for 16-bit 
BIOS ROM decoding. 


This bit is read/write at PR1(1). 
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CNF(9) - 46E8H/3C3H Select. 


This bit has no effect in Micro Channel applica- 
tions. 


0 = A4.7K pull-down on Pin MD9. Port 
O3C3H is selected as the VGA setup 
and enable register instead of Port 
46E8H in the AT interface. 


1 = No pull-down resistor. The internal pull- 
up sets CNF(9) = 1. Port 46E8H is 
selected as VGA setup and enable 
register. 


CNF(8) - Analog/TTL Display Status Bit. 


Whether provided with either a pull-up or pull- 
down external resistor, CNF(8) is latched internally 
at power-on-reset from memory data bus Pin 
MD11. 


Pulling up MDi1 causes CNF(8) to be latched 
Low. This bit controls no internal functions and is 
read only as Bit 3 of PR5 (8CF.OF). Also, CNF(8) 
is unaffected by writing to PR5 (8CF.0F). Sug- 
gested implementation is: 


0 = Analog (VGA - compatible) display is at- 
tached. 


1 = TTL (EGA - compatible) display is at- 
tached. 


CNF(7:4) - General Purpose Status Bits. 


Bits CNF(7:4) are latched internally at power-on- 
reset from corresponding memory data bus pins 
MD(7:4), provided with either pull-up or pull-down 
external resistors. 


Pulling down MD(7:4) causes CNF(7:4) to be 
latched high. 


These are read only bits at PR5 (8CF.OF) positions 
(7:4). These bits are unaffected by writing to 
PR5(3CF.0F). 
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CNF(3) - Video Clock Source Control. 


This bit cannot be written or read as I/O port. 
Pulling up MD3 causes CNF(3) to be latched high. 


It configures WD90C31A pins VCLK1 and VCLK2 
as inputs or outputs. 


= Inputs. 
1 = Outputs. 


When used as inputs, these pins supply alternate 
video dot clocks. Selection of dot clock is by an 
internal multiplexer. 


When used as outputs, VCLK1 supplies an active 
low load pulse for an external clock chip during 
I/O writes to Port 3C2H. This load pulse may be 
inhibited by setting PR11(2) = 1. VCLK2 becomes 
a third clock select input to the external clock chip, 
which supplies multiple dot clock frequencies to 
the VCLKO input. Also, VCLK2 and VCLK1 out- 
puts are equal to Bits 3 and 2 of the Miscel- 
laneous Output Register at 3C2H when PR15 Bit 
5= 1. 


CNF (2) - AT/MCA Bus Architecture Select. 


This bit cannot be written or read as I/O. Pulling 
down MD2 causes CNF(2) to be latched low. 

0 = Micro Channel architecture. 

1 = AT BUS architecture. 


Selecting CNF(2) changes the pinout definition 
between AT BUS and Micro Channel bus. (See 
Signal Description.) 


PC-AT BUS MICRO 

CHANNEL 
MEMCS16 CDDS16 
ROM16 CSFB OUT 


BOW s0s00 Tn 
RN |W 
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CNF(1) - ROM Configuration. 


With an 8-bit system interface [CNF(1) = 0]: 


Address bit AO =0, selects the even ROM. 
AO = 1, selects the odd ROM. 


With a 16-bit system interface, [CNF(1) and PR1 = 
1] enables ROM16. 


This bit can not be written or read. 


0 = No pull-down resistor on MD1. The inter- 
nal pull-up sets CNF(1) = 0 at power-on- 
reset. The WD90C31A’s data bus buffer 
controls are configured for one ROM 
(eight bits). PR1(1) can not be set high. 


1 = The WD90C31A’s data bus buffer con- 
trols are configured for 16-bits (as with 
two ROMs). Setting CNF(1) to 1 
enables the HTL output pin. 





CONFIGURATION REGISTER BITS CNF(18:0) 


CNF (0) - BIOS ROM Mapping. 


This bit may read or written at PR1(0). 


0 = No pull-down resistor on MDO. The in- 
ternal pullup resistor sets this bit to 0 at 
power-on-reset. 

1 = The BIOS ROM is mapped out. An ex- 


ternal 4.7 Kohm pull-down resistor sets 
CNF(0) = 1 on power-on-reset. 
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10.0 HARDWARE CURSOR 


The Hardware Cursor supports a user-defined 
pattern of up to 64 by 64 pixels, defined at 2 bits 
per pixel. The cursor pattern should be stored ina 
non-visible part of display memory. The cursor 
operates in all packed and planar VGA graphics 
modes, as well as VGA text modes. 


The Hardware Cursor is accessed at Port 
23C2H/23C3H when the register block pointer at 
Port 23COH has been set to 02H. 


LINDEX | FUNCTION, 


Index 0 
Index 1 
Index 2 
Index 3 


Cursor Control 

Cursor Pattern Address Low 
Cursor Pattern Address High 
Cursor Primary Color 
Cursor Secondary Color 
Cursor Origin 

Cursor Display Position X 
Cursor Display Position Y 
Cursor Auxiliary Color 


Index 4 
Index 5 
Index 6 
Index 7 
Index 8 





TABLE 10-1. CURSOR REGISTERS 


10.1 CURSOR CONTROL REGISTER, 
INDEX 0 


The Cursor Control register controls operation of 
the hardware cursor. 


FUNCTION 

15:12 | 0000 (Index) 
Cursor Enable 
Cursor Pattern Type 
er | Cursor Plane Protection 
Cursor Color Mode 

4:0 Reserved 

NOTE 

A write to either the Cursor Enable or the 
Cursor Pattern Type fields does not take 
effect until the beginning of a video frame 
following the next write to the Cursor 


Control Register. (In interlaced mode, it’s 
the next video field.) 
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Bits (15:12) - Index 0. 


Bit 11 - Cursor enable. 





O = Cursor is not displayed. 
1 = Cursor is displayed. 


Bits (10:9) - Cursor pattern type. 


00 = Cursor is 2 bits per pixel, 32x32 pixels. 
01 = Cursor is 2 bits per pixel, 64x64 pixels. 
10 = Reserved. 
11 = Reserved. 


Bit 8 - Cursor plane protection. 


O = Cursor plane protection disabled. 


1 = Cursor plane protection enabled. 


Bits (7:5) - Cursor color mode. 


000 = Software compatible cursor. 

001 = Two-color cursor with inversion. 

010 = Two-color cursor with special inversion. 
011 = Three-color cursor. 

100 = Reserved. 

101 = Reserved. 

110 = Reserved. 


111 = Reserved. 


Bits (4:0) 
Reserved. 


10.2 CURSOR PATTERN ADDRESS 


The two Cursor Pattern Address registers form a 
21-bit address, specifying the location in the 
display memory where the first byte of the cur- 
sor pattern is stored. This value is independent 
of the cursor origin. The cursor pattern may be 
stored anywhere in the display memory but is 
generally stored in a non-visible location. 
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Generally, this address represents the CPU address 
at which the pattern begins, minus the CPU address 
of the top-left corner of the screen, in whichever 
current VGA mode is in use. Not all addresses 
are valid in all modes. See the section on "Cursor 
Address Mapping." 


NOTE 

A write to either of the Cursor Pattern 
Address Registers or the Cursor Origin 
Register does not take effect until the 
beginning of a video frame following the 
next write to the Cursor Control Register. 
(In interlaced mode, it’s the next video 
field.) 


10.2.1 Cursor Pattern Address Low, Index 1 


FUNCTION 
15:12 | 0001 (Index) 


Cursor Pattern Address 
Bits 11:0. Bits 1 and 0 
| must be set to 0. 






— 
—k., 
ro) 








10.2.2 Cursor Pattern Address High, Index 2 


err [FUNCTION 
15:12 | 0010 (Index) 


Cursor Pattern Address 
Bits 20:12 


10.3. CURSOR ORIGIN, INDEX 5 


The Cursor Origin register specifies the offset in 
pixels from the top-left corner of the pattern which 
will be displayed at the cursor display position. 
This value is often referred to as the cursor’s "hot 
spot". 









NOTE 
For 32 by 32 cursor patterns each field is 
restricted to the values 31:0. 


HARDWARE CURSOR 


10.4 CURSOR DISPLAY POSITION 


The Cursor Display Position X and Y registers 
specify the location on the screen at which the 
cursor origin is displayed. These values represent 
a position in pixels, referenced to the top-left 
corner of the screen, regardless of the display 
mode. 











In text modes, the cursor position still represents 
pixels not characters. The cursor can be dis- 
played at any position on the screen, including 
between characters. 


NOTE 
A write to either Cursor Display Position 
X or Y register does not take effect until 
the beginning of the next video frame. (In 
interlaced mode, it’s the next video field.) 


10.4.1 Cursor Display Position X, Index 6 


BIT | FUNCTION 
15:12 | 0110 (Index) 


Reserved 


Cursor Display Position X 








10.4.2 Cursor Display Position Y, Index 7 


FUNCTION 
15:12 | 0111 (Index) 












Cursor Display Position Y 
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10.5 CURSOR COLOR REGISTERS 


The cursor color registers control the display of 
2-bit per pixel cursor patterns. 


The Cursor Primary Color, Cursor Secondary 
Color and Cursor Auxiliary Color registers specify 
eight-bit colors to be displayed for different parts 
of the cursor pattern. 


NOTE 
Even in planar mode, in which pixels are 
four bits each, these colors are eight bits 
per pixel. 


10.5.1 Cursor Primary Color, Index 3 


10.5.2 Cursor Secondary Color, Index 4 












BIT 
15:12 
11:8 


FUNCTION 
0100 (index) 
Reserved 


7:0 Cursor Secondary Color 





10.5.3 Cursor Auxiliary Color, Index 8 


FUNCTION 
15:12 | 1000 (Index) 


11:8 Reserved 

















Cursor Auxiliary Color 


10.6 CURSOR REGISTER UPDATES 


When a new cursor pattern is selected, up to four 
different registers must be updated. If a new 
video frame were to begin before all registers 
were updated, a single frame could be displayed 
with incorrect cursor data. While the display 
would recover within one video frame, the results 
would be visually annoying. Therefore, the 
WD90C31A holds off use of updated register data 
until all of the associated registers have been 
updated. 


Writing to either the Cursor Pattern Address 
register or the Cursor Origin register does not take 
effect until the beginning of a video frame follow- 
ing the next write to the Cursor Control register. 
Therefore, the Cursor Control register must be 
written to after updating either of these registers, 
even if the data in the Cursor Control register is to 
remain unchanged. However, reading any of 
these registers always returns the data last written 
to the register, whether or not such data has al- 
ready taken effect. 


A write to either Cursor Display Position X or Y 
register does not take effect until the beginning of 
the next video frame. In interlaced mode, updates 
occur at the beginning of the next video field. 


10.6.1 Cursor Address Mapping 


Cursor patterns are always stored in contiguous 
locations in display memory, usually in a non-visible 
portion, and always across all four maps. The 
definition of contiguous locations differs slightly by 
mode, as defined in Tables 10-2, 3 and 4. 


Each mode has restrictions on where a cursor 
pattern may begin and how such a pattern must 
be stored. The location where the currently re- 
quired cursor pattern is stored in display memory 
is loaded by the host into the Cursor Pattern Ad- 
dress registers, as defined in Tables 10-2, 3 and 4. 


The Cursor Pattern Address registers point to the 
doubleword starting region of the cursor pattern. 
They are not byte addresses and consecutive 
register values generally do not point to consecu- 
tive memory bytes. However, the cursor pattern 
must use all of the consecutive memory bytes (1K 
or 256 bytes) assigned to it starting from the byte 
pointed to. 
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Penhee Cursor Pattern Address Petia e Cursor Pattern Address 




























Bank 0 

A0000 © 

Map 0 0 If pattern starts here... 
Map 1 2) then next byte is here... 
Map 2 @ then here... 

Map 3 @ then here... 

A0001 






Map 0 and fifth byte is here 






AFFFF 
Map 0 
Bank 1 
A0000 
Map 0 










AFFFF ® 
y 





Map 3 1FFFF (Theoretical maximum for 


1K X 1K display memory.) 













TABLE 10-2. PLANAR MODES 


Cursor Pattern Address 


If pattern starts here... 











CPU 
Address 


Bank 0 
A0000 ® 









A0001 then next byte is here... 
A0002 then here... 
A0003 then here... 


“-OQ8008° 


A0004 and fifth byte is here 







AFFFC 
Bank 1 
A0O000 







Bank OF 





AFFFC ® | 3FFFF (Theoretical maximum for 


1K X 1K display memory.) 





TABLE 10-3. PACKED MODES 









Maps 0:1 
B8000 © 
B8001 
Maps 2:3 
B8000 
B8001 
Maps 0:1 
B8002 
B8003 














If pattern starts here... 
then next byte is here... 











then here... 
then here... 







OO of 





—_. 


and fifth byte is here 










3FFF 






BFFFE 
BFFFF 






See the following notes. 





TABLE 10-4. TEXT MODES 


NOTES 
® These locations are usually visible. In 
practice, cursor pattern is usually 
stored in non-visible memory. 


@ Cursor pattern must start in map 0 but 
pattern is stored on all maps. 


@ Some modes and/or boards may not 
support CPU addresses up to this 
level. Since up to 1K consecutive 
locations are required for the pattern, 
the pattern cannot actually start at the 
highest locations. 


@ In mode 7, CPU addresses are 
BO0O00-B7FFE. 
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10.6.2 Two-Bit Cursor Pattern Format 


The cursor pattern pointed to by the Cursor Pat- 
tern Address registers for two-bit cursor patterns 
is stored in either 1K or 256 consecutive memory 
byte locations. The cursor pattern data is stored 
for 64 by 64 and 32 by 32 cursors as follows: 


10.6.2.1 Cursor Pattern - 2-Bit, 64 x 64 Cursors 


Offset | Map Cursor Pattern 
® @ @ ® 


AND plane, row 0, col. 

XOR plane, row 0, col. 0-7 
AND plane, row 0, col. 
XOR plane, row 0, col. 












AND plane, row 0, col. 
XOR plane, row 0, col. 16-23 
AND plane, row 0, col. 
XOR plane, row 0, col. 












AND plane, row 0, col. 
XOR plane, row 0, col. 32-39 
AND plane, row 0, col. 
XOR plane, row 0, col. 

















AND plane, row 0, col. 
XOR plane, row 0, col. 48-55 
AND plane, row 0, col. 
XOR plane, row 0, col. 










AND plane, row 1, col. 
XOR plane, row 1, col. 0-7 
AND plane, row 1, col. 
XOR plane, row 1, col. 







ae 









NO 
O1 
Ol 


AND plane, row 63, col. 48-55 
XOR plane, row 63, col. 48-55 
AND plane, row 63, col. 56-63 
XOR plane, row 63, col. 56-63 







NOTES 
® Offset is relative to the value in the 
Cursor Pattern Address register. 


@ In packed mode, Map is selected by 
the two low-order CPU address bits. 


@ Cursor pattern must start in map 0 but 
pattern is stored on all maps. 








@ Within each byte, the high-order bit 
represents the left most column. 


10.6.2.2 Cursor Pattern - 2-Bit, 32 x 32 Cursors 


“Offset | Map Cursor Pattern 


AND plane, row 0, col. 0-7 
XOR plane, row 0, col. 0-7 
AND plane, row 0, col. 8-15 
XOR plane, row 0, col. 8-15 













AND plane, row 0, col. 
XOR plane, row 0, col. 16-23 
AND plane, row 0, col. 
XOR plane, row 0, col. 











AND plane, row 1, col. 
XOR plane, row 1, col. 0-7 
AND plane, row 1, col. 
XOR plane, row 1, col. 






OnmM-OoO;|wn-O!1WNM Oo 


me 









AND plane, row 1, col. 
XOR plane, row 1, col. 16-23 
AND plane, row 1, col. 
XOR plane, row 1, col. 









owns 






AND plane, row 31, col. 16-23 
XOR plane, row 31, col. 16-23 
AND plane, row 31, col. 24-31 
XOR plane, row 31, col. 24-31 







10.6.3 Loading the Cursor Pattern 


Loading a cursor pattern requires writing the pat- 
tern to a non-visible portion of display memory, 
then pointing to the pattern with the Cursor Pattern 
Address registers (Index 1, 2). A cursor pattern al- 
ready in display memory can be selected simply by 
loading these registers. 


In some VGA modes, certain maps are not defined 
but the physical RAM connected to those maps 
appears at higher memory locations in the maps 
that are defined. For instance, the first byte of map 
2 may appear as the 64th Kbyte in map 0. There- 
fore a cursor pattern that occupies contiguous 
locations in one mode may appear fragmented in 
other modes. It is the responsibility of the software 
to track these fragments and assure that no part of 
the pattern will be accidentally overwritten. 
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10.6.4 Cursor Color Modes 


A cursor may be displayed using any of four color 
modes selected by the Cursor Color Mode field of 
the Cursor Control Register (Index 0). Depending 
on the color mode selected, each 2-bit pixel of the 
cursor pattern will be displayed against the back- 
ground as described in Table 10-5. 


The "special" color generates the exclusive-NOR 
(XNOR) of the background and the Auxiliary Color 
Register (Index 8). This retains the "different from 
background” color property of inversion while adding 
the ability to specify one preferred "special inversion" 
from a background color to any desired color. 


To use this feature, the Cursor Color Mode field 
must be set to "special", and the Cursor Auxiliary 
Color should be loaded with the exclusive NOR 
(XNOR) of the background color to be translated 
and the desired color to be displayed. When set 
in this manner, any screen pixel of the former 
color covered by an inverting cursor pattern pixel 
will be "inverted" into the auxiliary color. 


10.6.5 Compatibility Differences Between 
Hardware and Software Cursor 


Some cursor colors may display differently using 
the hardware cursor than when using a software 
cursor. This can happen in Planar Modes, be- 
cause a software cursor modifies memory data 
that is then passed through the Attribute Control- 
ler’s Palette registers, while the hardware cursor 
operates on data at the output of the Attribute Con- 
troller’s Palette registers. The section on "Cursor 
Plane Protection" explains how to minimize these 
incompatibilities. 


CURSOR 
PATTERN © 
00 


















Inverted 


COLOR COLOR COLOR COLOR 
MODE 0 MODE 1 MODE 2 MODE 3 


All Os Secondary Secondary Secondary 
01 All 1s Primary Primary Primary 
Transparent Transparent Transparent Transparent 





Inverted 
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10.6.6 Cursor Plane Protection 


In 256-color modes, a background pixel covered 
by the cursor is either replaced by a specified 8-bit 
color or is inverted. For other modes, cursor 
plane protection is available. 


When the Cursor Plane Protection bit of the Cur- 
sor Control register is set, some bits of the back- 
ground are handled differently. In these cases the 
two or four high-order bits of the background are 
replaced with the corresponding bits of the Cursor 
Auxiliary Color register (Index 8). 


When bit 7 of the VGA Attribute Mode Control 
register (Port 3COH/3C1H, Index 10H) is reset, 
cursor plane protection applies to the two high- 
order bits of the background. When this bit is set, 
protection applies to the four high-order bits. 


This feature is designed to provide as much 
flexibility and compatibility with a software cursor 
as possible, due to the processing done by the 
VGA attribute controller. 


















Special @ Auxiliary 


TABLE 10-5. CURSOR COLOR MODES 


NOTES 
® The high-order bit of each 2-bit pattern is the AND mask, the low-order bit is the XOR mask. 


@ Result is Background XNOR’d with the auxiliary color. 





17-88 


9/3/92 of 


HARDWARE BITBLT 


11.0 HARDWARE BITBLT 


The BITBLT hardware supports accelerated data 
transfers between regions of display memory. 
Display memory regions may be rectangular or 
linear. 


A full complement of raster operations are avail- 
able. Color expansion and transparency, useful 
for accelerating text modes as well as plane 
masking, are also supported. 


This same hardware can be used to rapidly copy 
8 by 8 patterns and fill rectangles. 


The BITBLT hardware supports text modes and 
monochrome, 4-bit and 8-bit color modes, as well 
as the 16-bit color mode. 


Index 0 BITBLT Control - part 1* 
BITBLT Control - part 2 
BITBLT Source Low 
BITBLT Source High 
BITBLT Destination Low* 
BITBLT Destination High* 
BITBLT Dimension X 
BITBLT Dimension Y 
BITBLT Row Pitch 
BITBLT Raster Operation 
BITBLT Foreground Color 
BITBLT Background Color 
BITBLT Transparency Color 


Index 1 
Index 2 
Index 3 
Index 4 
Index 5 
Index 6 
Index 7 
Index 8 
Index 9 
Index A 
Index B 
Index C 
Index D 
Index E 


BITBLT Transparency Mask 
BITBLT Map And Plane Mask 


* All or part of these registers can change 
automatically. 


TABLE 11-1. BITBLT REGISTERS INDEX 
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11.1 CONTROL AND STATUS 


BITBLT Control - Part 1, Index 0 


FUNCTION 
0000 (Index) 
















"12 
BITBLT Activation/Status* 
BITBLT Direction 
BITBLT Addressing Mode 
6 
4 
2 


BITBLT Destination 
Select 


BITBLT Source Format 


BITBLT Source Select 


* This bit is automatically reset 
when BITBLT is completed. 


$8 | | 
Source Linearity 






Bits (15:12) - Index 0. 


Bit 11 - BITBLT Activation/Status. 


Writing a 1 to this bit starts a BITBLT operation 
using the currently loaded register values. This bit 
is reset automatically when the BITBLT operation 
is completed. Therefore, reading a 1 from this bit 
indicates that a BITBLT operation is in progress. 


Writing a 0 to this bit will not start a BITBLT opera- 
tion but may be useful in "quick start" mode to set 
the other bits in the register for the coming series 
of quick-start operations. 


CAUTION 
Writing a 0 to this bit while a BITBLT 
operation is in progress may cause un- 
expected and unrecoverable results. 


0 = Do not start BITBLT (write), BITBLT com- 
pleted (read). 


1 = Start BITBLT (write), BITBLT in progress 
(read). 





x 
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Bit 10 - BITBLT Direction. Bits (1:0) - BITBLT Source Select. 
0 = BITBLT direction is top to bottom, left to 00 = Source is screen memory. 
right. 


10 = Source is system I/O location, 32 bits. 
1 = BITBLT direction is bottom to top, right to 


left X1 = Reserved for future expansion. 


BITBLT Control - Part 2, Index 1 


FUNCTION 


Bits (9:8) - BITBLT Address Mode. 






00 = Planar Mode (includes monochrome 






modes). 
01 = Packed Mode, includes text and 256- 15:12] 0001 (Index) 
chiar 






1X = Reserved for future expansion. 


BITBLT Interrupt Enable 
oa [Reened 


ITBLT Quick Start 


BITBLT Update Destina- 
tion 
B 


ITBLT Pattern Select 


BITBLT Monochrome 
Transparency 






Bits (7:6) - BITBLT Destination/Source 
Linearity. 





When the Destination or Source region of a 
BITBLT operation is specified as linear, each row 
of that region is considered to begin at the 
doubleword immediately following the doubleword 
containing the last pixel of the preceding row. The 
alignment of the first pixel in each line is the 
same. No doubleword will straddle two lines and 
there may be gaps at unused pixels between ad- 
jacent lines. 









BITBLT Transparency 
Polarity 


Reserved, must be 0 


BITBLT Transparency 
Enable 


Bits (15:12) - Index 1. 





Bit 7 controls the destination area, Bit 6 controls 
the source area. 





0 = Area is rectangular. 





1 = Area is linear. 


Bits (5:4) - BITBLT Destination Select. 
Bit 11 


00 = Destination is screen memory. 
Reserved. 


10 = Destination is system I/O location. 


X1 = Reserved for future expansion. Bit 10 - BITBLT Interrupt Enable. 


0 = Do not interrupt on completion of BITBLT. 


Bit :2) - BITBLT F : 
MS kese) BeURCe oumel 1 = Interrupt on completion of BITBLT. 


00 = Source format is color. 


01 = Source format is monochrome from Bits (9:8) 
color comparators. Reserved. 


10 = Source format is fixed color (filled rec- 
tangle). 


11 = Source format is monochrome from host. 
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Bit 7 - BITBLT Quick Start. 


Quick Start Mode 
When BIT 7 is set, BITBLT starts automatically as 
soon as the BITBLT Destination Low register 
(Index 4) is written, unless automatic destination 
update is enabled for BITBLT, in which case the 
BITBLT starts automatically when the BITBLT 
Source Low register (Index 2) is written. 


This mode permits a chain of BITBLT operations to 
be performed with one less register write operation 
than would otherwise be required. All other bits in 
the BITBLT Control register operate as they were 
last written, and the BITBLT Activation bit is physi- 
cally set and can be read back normally. 


0 = BITBLT starts only when explicitly 
enabled. 


1 = BITBLT starts automatically when des- 
tination register is written, or source 
register if destination update is enabled. 


BIT 6 - BITBLT Update Destination. 


Automatic Destination Update 

A host doing multiple BITBLTs need only update 
those registers that change from one BITBLT to the 
next. Most BITBLT registers never change unless 
written by the host. The exceptions to this are the 
two BITBLT Destination registers (Index 4, 5) and 
the status bit in the BITBLT Control register (Index 
QO). 


When bit 6 of this register is set, the BITBLT Des- 
tination registers are automatically updated at the 
end of each BITBLT operation to point to the rec- 
tangular region immediately to the right of the pre- 
vious destination region. This is specifically aimed 
at improving text output operations. When the 
destination area is specified as linear rather than 
rectangular, the destination registers point to the 
location immediately past the previous destination 
area. 


0 = Do not update destination on completion 
of BITBLT. 


1 = Update destination on completion of 
BITBLT. 
Bits (5:4) - BITBLT Pattern Select. 


00 = Patterns are not used. 
01 = 8X8 patterns are used for source. 
1X = reserved for future expansion. 
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Bit 3 - BITBLT Monochrome Transparency. 


0 = Monochrome transparency is not 
enabled. 


1 = Monochrome transparency is enabled. 


Bit 2 - BITBLT Transparency Polarity. 


0 = Matching pixels are transparent. 


1 = Matching pixels are opaque. 


Bit 1 
Reserved, must be set to 0. 


Bit 0 - BITBLT Transparency Enable. 


0 = Destination transparency is not enabled. 
1 = Destination transparency is enabled. 


11.2 SOURCE AND DESTINATION 


The BITBLT Source Low and BITBLT Source High 
registers specify the source address for BITBLT 
operations. The BITBLT Destination Low and 
BITBLT Destination High registers specify the 
destination address. The high and low fields of 
each register pair are concatenated to form a 21- 
bit address pointing to the starting corner of the 
source or destination area. 


The starting corner for source and destination will 
be either the top-left or bottom-right corner. The 
corner specified must be coordinated with the 
BITBLT Direction bit of the BITBLT Control register. 


When the source and destination areas do not 
overlap, BITBLT can be started in either corner. 
When these areas overlap, the corner and direc- 
tion must be selected to prevent parts of the 
source area from being overwritten by the destina- 
tion array before they are copied. 


When the BITBLT Update Destination bit in the 
BITBLT Control register is set, the host should not 
read the BITBLT Destination registers while a 
BITBLT is in progress, since these registers 
change just before the end of the operation. 


When the BITBLT Quick Start bit in the BITBLT 
Control Register is set, writing these registers may 
automatically start BITBLT operations. 
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11.2.1 BITBLT Source Low, Index 2 11.3.1 Monochrome and Planar Modes 


CPU BITBLT DISPLAY MEMORY 
ADDRESS | REGISTER LOCATION 
ADDRESS (ALL MAPS) 


A0000 0 Location 0, bit 7 
(left most pixel). 
1 Location 0, bit 6. 
i) J i 
7 Location 1, bit O 
(right most pixel). 







FUNCTION 
0010 (Index) 


11:0 BITBLT Source Position 
Bits 11:0 


11.2.2 BITBLT Source High, Index 3 


FUNCTION 
0011 (Index) 
Reserved (Must Be 0) 

memory locations. 


BITBLT Source Position - 
Bits 20:12 
@ Not in the same memory page as A0001 


11.2.3 BITBLT Destination Low, Index 4 above. 


FUNCTION 














A0001 8 Location 1, bit 7. 
y ’ y 
AFFFF @ 2M-1 Location 256K-1, bit 0 
®, 


® Last location in a 1 MB system. Smaller 
memory configurations have fewer display 














11.3.2 Packed Modes 


CPU BITBLT DISPLAY MEMORY 
ADDRESS | REGISTER LOCATION 
ADDRESS (ENTIRE BYTE) 
0 


15:12} 0100 (Index) 
1:0 
Map 0, location 0, 


| BITBLT Destination 
Position - Bits 11:0 
(left most pixel). 


11.2.4 BITBLT Destination High, Index 5 Map 1, location 0. 


Map 2, location 0. 
Map 3, location 0, 
BIT FUNCTION (right most pixel). 
15:12} 0101 (Index) 
1:9 | Reserved (Must Be 0) 


BITBLT Destination 
Position - Bits 20:12 










oS 






A0004 4 Map 0, location 1, 
(left most pixel). 
ui y i) 
A0007 7 Map 3, location 1, 
(right most pixel). 
U U i 
11.3. ADDRESS MAPPING AFFFF © 1M-1 Map 3, location 256K-1. 
The source and destination addresses are partially © 


mode dependent. Addresses represent the char- ® Last location in a 1 MB system. Smaller 
acter or pixel at the starting corner of the move, memory configurations have fewer display 
which may be the top left or bottom right corner. memory locations. 
@ Not in the same memory page as A0007 
above. 
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The location referred to in sections 9.2.1 and 9.2.2 
is the CPU address offset in bytes from the top of 
the display memory for any given mode. For ex- 
ample, where display memory starts at CPU ad- 
dress AQOOOH, location 123H would correspond to 
CPU address A0123H. Where display memory is 
divided into pages, the location is calculated as if 
all pages were consecutive. For example, with dis- 
play memory pages of 64 Kbytes, location 10123H 
would correspond to CPU address A0123H in the 
second page of the display memory. 


When the source or destination of a BITBLT 
Operation is not a memory location, the cor- 
responding pair of position registers are unused 
and may contain any value, except that the two or 
three low-order bits of the BITBLT Source Low 
register are still used to specify a source align- 
ment of the data. 


11.4 DIMENSIONS AND ROW PITCH 


11.4.1 BITBLT Dimension X, Index 6 


FUNCTION 
0110 (Index) 


11:0 BITBLT Dimension X * 










* legal range is 1 to 2K pixels 





The BITBLT Dimension X register specifies the 
width of the rectangular region to be copied. 


In Graphic Modes, this value is expressed in 
pixels. 


In Text Modes, this value is expressed in the num- 
ber of characters multiplied by eight (even though 
each character is stored using only two bytes). 
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11.4.2 BITBLT Dimension Y, Index 7 


FUNCTION 


15:12 | 0111 (Index) 
BITBLT Dimension Y * 


* legal range is 1 to 2K pixels 


The BITBLT Dimension Y register specifies the 
height of the rectangular region to be copied. 











In Graphic Modes, this value is the height of the 
region in pixels. 


In Text Modes, this value is the height of the 
region in character rows. 


11.4.3 BITBLT Row Pitch, Index 8 


FUNCTION 
1000 (Index) 
BITBLT Row Pitch * 


* In Packed Mode, the two low 
order bits of this field must be 
zero. 

In Planar Mode, the three low 
order bits must be zero. 





The BITBLT Row Pitch register specifies the linear 
offset from any location in a given row to the same 
location in the next row. This offset is in the same 
units as the source and destination fields to which 
it applies. 


When both source and destination are rectangular 
areas, the BITBLT Row Pitch applies to both 
areas. When either or both are non-rectangular, 
the offset does not apply to that range. 
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11.5 FOREGROUND AND BACKGROUND 
COLORS 


The BITBLT Foreground and Background Color 
registers specify 8-bit or 4-bit digital colors to be 
used when expanding monochrome source areas. 
The foreground color can also be specified as the 
source of a BITBLT to produce a filled rectangle. 


BITBLT Foreground Color, Index A 


a 
15:12 | 1010 (Index) 


7:0 BITBLT Foreground 
Color * 









* In Planar modes, only bits 3:0 
are used to specify a color. 





BITBLT Background Color, Index B 


BIT FUNCTION 


15:12 | 1011 (Index) 


11:8 Reserved 


7:0 BITBLT Background 
Color * 
* In Planar modes, only bits 3:0 
are used to specify a color. 












11.6 MAP AND PLANE MASK 


The BITBLT Mask register controls both Plane 
and Map Masks used in BITBLT. 


The BITBLT Map Mask field specifies a four-bit 
mask that prevents data in the specified maps 
from being updated. This map is needed for 
BITBLT in all text modes to prevent font data from 
being overwritten in a character-attribute move 
and vice versa, and VGA mode F. It can also be 
used in VGA modes 4, 5 and 6 for partial 
hardware support. Additionally, it can be used in 
VGA modes D, E, 10, 11 and 12 and extended 
Planar modes as a Plane Mask if desired. 


The BITBLT Plane Mask field specifies an eight- 
bit mask that prevents data in the specified planes 
from being updated. It is useful in VGA Mode 13 
and extended Packed modes when Plane Mask- 
ing is desired. 


BITBLT Mask - VGA, Index E 


BIT FUNCTION 


15:12 | 1110 (Index) 


7:0 BITBLT Plane Map Mask 
Mode * 


* |n Planar Modes, only bits 3:0 
are used. 


BITS BITBLT 
7:0 PLANE MASK 


XXXX XXXO | Plane O Disabled 


i [ 








17-94 


9/3/92 Ga 


HARDWARE BITBLT 
BITBLT 


BITS 
3:0 MAP MASK 


XXX0 Map 0 Disabled 
XXX1 Map 0 Enabled 


OXXX 


1XXX Map 3 Enabled 


Map 3 Disabled 


Let eieed 





11.7. RASTER OPERATIONS 


The BITBLT Raster Operation register specifies a 
bitwise logical operation to be performed on the 
source and destination fields. This field is always 
active and must be loaded with the appropriate 
value even when a simple source copy is to be 
performed. 


BITBLT Raster Operation, Index 9 


FUNCTION 
15:12 | 1001 (Index) 


11:8 BITBLT Raster Operation, 
abcd in Table 11-3. 


All BITBLT operations apply a source color, pat- 
tern or area to a destination area. The result writ- 
ten to the destination is a logical function of the 
source and destination pixels for each location. 











The Raster Operation code is defined as follows: 


The Source (S) and Destination (D) form a 2-bit 
value. The Truth Table (Table 11-2) defines the 
results of the two operands, Source and Destina- 
tion, for the desired function. 


The four 1-bit results of the Truth Table for the 
desired operation in the form "abcd" form the 
Raster Operation code (Table 11-3). The "a" is 
defined as the high-order bit of the code. 


While the Raster Operation code represents a 2- 
input operation, both inputs are not always 
relevant in the operation. For example, codes 
0011 (source copy) and 1100 (inverted source 
copy) are independent of the destination field. 
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Arithmetic operations are not supported. 





TABLE 11-2. 
BITBLT TRUTH TABLE 












1011 | S4D 
ci 
ron_jon | [Ore 


TABLE 11-3. 
RASTER OPERATION CODE 


















11.8 PATTERNS 


The WD90C31A has a special mode to accelerate 
the copying of 8 by 8 source patterns. In this 
mode, an 8 by 8 full-color or monochrome pattern 
can be repetitively applied to a large destination 
area in an efficient manner. 


To perform a pattern copy, the host first writes the 
8 by 8 pattern to display memory in a linear 
fashion, usually to a non-visible location, depend- 
ing on the current addressing mode, as described 
in Sections 11.7.1 and 11.7.2. The host then 
loads the BITBLT Source registers, with the loca- 
tion of the pixel within the pattern corresponding 
to the top-left corner of the destination region. The 
BITBLT Pattern Select field of the BITBLT Control 
register must be Set to 8 by 8 patterns. 
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To specify a monochrome pattern, the host must 
write a color pattern in the current mode, planar or 
packed, and then use the control registers to 
specify a single plane of the source to be used. 


11.8.1 BITBLT Pattern Storage - Monochrome 
and Planar Modes 


In planar mode, the 8 by 8 source pattern must be 
stored in display memory in a 32-byte aligned 
area. It is stored as 64 consecutive pixels, not as 
a rectangular region. When performing the pat- 
tern copy, however, the source address may point 
to any pixel within the 64-pixel region. This pixel 
is anchored to the top-left corner of the destination 
region, and the pattern wraps to the right and 
down from that point. 


REGISTER 
ADDRESS 


DISPLAY MEMORY 
CONTENTS 


Any data. 


n* ton+7 | All maps, top row of 


8X8 pattern. 


n+é8to 
n+15 


All maps, second 
row of 8X8 pattern. 


n + 56 to All maps, bottom 


n+63 row of 8X8 pattern. 
n+641to..| Any data. 


*’n’ must be a multiple of 64 





11.8.2 BITBLT Pattern Storage - Packed Modes 


In packed mode, the 8 by 8 source pattern must 
be stored in display memory in a 64-byte aligned 
area. It is stored as 64 consecutive bytes, not as 
a rectangular region. When performing the pat- 
tern copy, however, the source address may point 
to any pixel within the 64-pixel region. This pixel 
is anchored to the top-left corner of the destination 
region and the pattern wraps to the right and 
down from that point. 


REGISTER | DISPLAY MEMORY 
ADDRESS CONTENTS 


Any data. 


Top row of 8X8 pat- 
tern, left most pixel. 


Top row of 8X8 pat- 
tern, second pixel. 


Top row of 8X8 pat- 
tern, right most 
pixel. 


Second row of 8X8 
pattern, left most 
pixel. 


Bottom row 8X8 
pattern, right most 
pixel. 


n + 64 Any data. 


*’n’ must be a multiple of 64 





11.9 MONOCHROME TO COLOR 
EXPANSION 


When the source of a BITBLT operation is 
monochrome, each 0 in the source region is 
replaced with the specified background color, 
while each 1 is replaced with the foreground color. 
All other processing options, including masks and 
raster operations, remain active and operate on 
the expanded colors. 


When the source is specified as a fixed color, the 
entire destination will be filled with the foreground 
color, subject to masks, raster operations and 
destination transparency. Filled rectangles are 
generated in this manner. 


When a monochrome source is generated by the 
color comparators, color destination transparency 
is generally not available since the transparency 
color registers are in use. 
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11.10 EXTRACTING MONOCHROME DATA 


Monochrome data can be extracted from color 
data read from display memory by the color com- 
parators. Data extracted in this manner is repli- 
cated to each plane or map as if it had been read 
from the memory. 


Monochrome data can also be extracted from host 
data when the BITBLT source is the 1/O port. In 
this case, each 32-bit word written to the I/O port 
is treated in the same manner as if it had been 
read from display memory. Alternately, the host 
may send monochrome data through the |/O port 
that does not require extraction (see section 11.14). 


To extract a single plane from a color source field, 
the BITBLT Transparency Color register should be 
loaded with FFH (all ones), while the BITBLT 
Transparency Mask register should be loaded 
with a 0 in the map or plane position to be ex- 
tracted, and a1 in all other positions. 


Monochrome data is usually extracted as a 
specific bit of each 4-bit or 8-bit pixel. However, 
the color comparators can be used to extract any 
color, or any maskable group of colors, into the 
monochrome color 1, with all other colors return- 
ing a monochrome 0. 


When the Monochrome Transparency bit is set in 
the BITBLT Control register, monochrome source 
pixels of 0 do not modify the destination, regard- 
less of any selected raster operation. 


The Transparency Enable and Polarity bits in this 
register have no effect on monochrome data ex- 
traction. 


11.11 COLOR TRANSPARENCY 


Color transparency is the concept that a certain 
color or range of colors in the source or destina- 
tion field of a BITBLT are actually transparent, with 
the rest being opaque. Transparent source colors 
do not overwrite the background. Opaque aes- 
tination colors cannot be overwritten. A common 
simplified form of source transparency is the logi- 
cal OR of source and destination, in which a 
source field of zero is effectively a transparent 
color, since when OR’ed with the destination, it 
does not change. 


Color destination transparency is supported by the 
WD90C31A, in addition to the more limited 
monochrome transparency described elsewhere. 


11.11.1 BITBLT Transparency Color, Index C 


7:0 BITBLT Transparency 
Color * 


* In Planar Modes, only the four 
low-order bits are used. 





The BITBLT Transparency Color register specifies 
an 8-bit or 4-bit color to be used as the transparency 
color. 


11.11.2 BITBLT Transparency Mask, Index D 


B 
15:12 | 1101 (Index) 


7:0 BITBLT Transparency 
Mask * 


* In Planar Modes, only the four 
low-order bits are used. 





The BITBLT Transparency Mask register specifies 
an 8-bit or 4-bit mask for use in comparison 
against the transparency color. 


The pixels of the destination are compared against 
the Transparency Color under control of the 
Transparency Mask. Each bit of the Transparency 
Mask that is a 1 makes the corresponding bit of the 
Transparency Color a "don't care". 


The BITBLT Transparency Enable bit of the 
BITBLT Control register (Index 1) specifies 
whether Color Transparency is enabled or dis- 
abled. The BITBLT Transparency Polarity bit 
specifies whether pixels matching the Transparen- 
cy Color are considered transparent. In this case, 
only destination pixels matching the transparent 
color can be overwritten, or transparent, and only 
non-matching pixels can be overwritten. 
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11.12 FILLED RECTANGLES 


Filled rectangles can be drawn very efficiently by 
the BITBLT hardware. A filled rectangle is simply 
a BITBLT with a source of a fixed color. To drawa 
filled rectangle, the host sets the Source Format 
field in the BITBLT Control register (Index 0) to 
"fixed color" and the Foreground Color register 
(Index A) to the desired fill color. A source ad- 
dress is not required. All other BITBLT options are 
available in a normal manner. 


11.13 SYSTEM MEMORY TO DISPLAY 
MEMORY OPERATIONS 


To copy data from system memory to display 
memory, the host may specify the source of a 
BITBLT as a system 1/O location rather than dis- 
play memory. In this case, display memory reads 
come from the 32-bit readback latch written by the 
host. 


After starting the BITBLT operation, the host 
writes a series of doublewords to the readback 
latch. This 32-bit register is accessed by two con- 
secutive writes to the 16-bit BITBLT 1/O port, 
with the low-order word of this register written first. 
This port may also be accessed by two 8-bit 
writes as long as the even port is accessed first. 
At the beginning of each BITBLT operation, the 
internal pointer is reset to the low-order word. 


When a source read is required and data from the 
host is unavailable, the WD90C31A suspends the 
BITBLT operation until data becomes available. 
Similarly, when the host attempts to write the 
register before previous data in it has been 
processed, the WD90C31A holds off the host. 


Conceptually, the 32 bits written by the host exactly 
replace the 32 bits that would have been read 
from the display memory. Just like the destina- 
tion, the source may have any alignment. The 
two or three low-order bits (Packed or Planar 
Mode) of the BITBLT Source Low register (Index 
2) specify the alignment of the source region. The 
other bits of the BITBLT Source Low register may 
have any value. That is, the pixel of the source 
word pointed to by those low-order bits cor- 
responds to the first pixel of the destination. 


HARDWARE BITBLT 


NOTE 

Source writes from the host are always 
performed in 32-bit groups, however the 
data is written to a 16-bit port. Therefore 
the host must always perform two 16-bit 
I/O writes at a time to the port, even 
when the remaining width is less than 
four or eight pixels. 


Just like display memory, no source doubleword 
from the host may straddle two lines of the destina- 
tion. 


11.14 DISPLAY MEMORY TO SYSTEM 
MEMORY OPERATIONS 


To copy data from display memory to system 
memory, the host may specify the destination of a 
BITBLT as a system //O location rather than display 
memory. In this case, display memory writes are 
replaced by writes to a 32-bit register read by the 
host. 


This 32-bit register is accessed by two consecutive 
reads of the 16-bit BITBLT I/O port. The low-order 
word of this register is read first. This port may 
also be accessed by two 8-bit reads, as long as 
the even port is accessed first. At the beginning of 
each BITBLT operation, the internal pointer is reset 
to the low-order word. 


When a destination write is required and the host 
has not read data from the previous write, the 
WD90C31A suspends the BITBLT operation until 
the host catches up. Similarly, when the host at- 
tempts to read the register before data is available, 
the WD90C31A holds off the host. 


Conceptually, the 32 bits read by the host exactly 
match the 32 bits that would have been written to 
the display memory. Unlike outputting to display 
memory, the destination is always doubleword 
aligned, that is, the first pixel of the source cor- 
responds to the first pixel of the destination. 


NOTE 

Source reads by the host are always per- 
formed in 32-bit groups, however the 
data is read from a 16-bit port. Therefore 
the host must always perform two 16-bit 
I/O reads at a time from the port, even 
when less than 32 bits remain in the cur- 
rent line. 


Just like display memory, no destination 
doubleword to the host may straddle two lines of 
the source. 
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11.15 SYSTEM MEMORY TO DISPLAY 
MEMORY TRANSFERS WITH COLOR 
EXPANSION 


The host may transfer monochrome data from 
system memory to display memory and, in the 
process, expand it to any two colors or any one 
color plus transparent. 


To accomplish this, the host sets the BITBLT 
Source Select field in the BITBLT Control register 
(Index 0) to "System I/O Location" and the BITBLT 
Source Format field to "Monochrome From Host". 
If transparency is desired, the Monochrome 
Transparency bit is also set. The BITBLT 
Foreground and Background Color registers 
(Index A and B) may also be set. 


WD90C31A 


The host then issues a series of 16-bit I/O writes 
to the BITBLT I/O port which are expanded to 
eight 4-bit pixels. The remaining eight high-order 
bits are ignored. In Packed Mode, the four low- 
order bits are expanded to four 8-bit pixels and 
the remaining 12 bits are ignored. 


The low-order bits of the BITBLT Source register 
(Index 2) work as in other system-to-video 
memory transfers. 


No source word may straddle two lines of the des- 
tination. All other BITBLT options work normally in 
this mode. 
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12.0 EXTENDED REGISTER ACCESS 


All of the WD90C31A enhanced functions are con- 
trolled by one or more extended registers, most of 
which are above and beyond standard VGA 
registers. 


Enhanced functions are controlled by indexed 
register blocks. Each indexed register block can 
contain up to sixteen 12-bit indexed registers. 
The 4-bit register index is written, along with the 
12-bit data field, to form a 16-bit word. 


Access to VGA-type registers is described in section 
5. This section only describes the access to in- 
dexed register blocks. 


12.1 ACCESSING INDEXED REGISTERS 


To write to one or more indexed registers within 
any register block, that register block must first be 
selected by loading its address into the Register 
Block Pointer field of the Index Control register. 
This causes the selected register block to appear 
at the Register Access port. 


A 16-bit word is then written to the Register Ac- 
cess port. The four high-order bits specify the 
Index of the individual register being written, while 
the 12 low-order bits are the data to be written. 
Additional registers within the same register block 
may then be written without re-selecting that 
register block. 


To read one or more indexed registers within a 
register block, the address of that register block is 
written to the Register Block Pointer Field, bits 7:0 
of the Index Control Register at Port 
23C0H/23C1H and the desired starting register to 
be read within the block is written to the Register 
Index Field, bits 11:8 of this register. Both fields 
are set with the same 16-bit write. This Causes 
the selected register to appear at the Register 
Access port located at 23C2H/23C3H. 


A 16-bit word is then read from the Register Access 
port. When reading an indexed register, the value 
returned contains the index of the register in the 
four high-order bits. 


lf the Auto-Increment Disable bit in the Index Con- 
trol register is reset, consecutive reads to the 


EXTENDED REGISTER ACCESS 


by register 0 and cycling indefinitely as long as 
reads continue. Addressing a non-existant 
register results in zeros being returned in the 12- 
bit data field. | 


If the Auto-Increment Disable bit is set, consecu- 
tive reads return the same indexed register. 


GLOBAL PORT MAP 


Port 23COH | Index Control 
register (low byte) 
















Port 23C1H Index Control 


register (high byte) 





Port 23C2H 





Register Access 
Port (low byte) 





Port 23C3H | Register Access 


Port (high byte) 
BITBLT I/O Port 
BITBLT I/O Port 


Reserved 






Port 23C4H 
Port 23C5H 
Port 23C6H 
Port 23C7H 







Reserved 


INDEX CONTROL REGISTER 
PORT 23C0H/23C1H 


12.2 


Except for bit 13 which is a read only, the Index 
Control register is a read/write register which con- 
trols reads and writes to indexed registers blocks. 


FUNCTION 


13 Invalid register block. 
This bit is read only 


Auto-increment disable 










1 
Register Index. 
Register Block Pointer 








Register Access port will return consecutively in- Bits (15:14) 

dexed registers within the same register block. Reserved 

Registers are read in ascending order through 

register F (the 16th register in the block), followed 
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Bit 13 - Invalid Register Block (read only). 


0 = Currently addressed register block exists 
on this device. 


1 = Currently addressed register block does 
not exist on this device. 


Bit 12 - Auto-increment Disable. 


0 = Consecutive reads return consecutive 
indexed registers. 


1 = Consecutive reads return the same 
indexed register. 
Bits (11:8) - Register Index 


The index of the desired starting register to be read 
within a block is written to these bits. When read, 
these bits return the index of the next register to be 
read. 


Bits (7:0) - Register Block Pointer 


To read one or more indexed registers within a 
register block, the address of that register block is 
written to this field. 


REGISTER BLOCK MAP 


Register Access 
Port Accesses 





00 System Control registers 
01 BITBLT registers 
02 Hardware Cursor 


registers 


12.3. INTERRUPT STATUS REGISTER, 


SYSTEM CONTROL REGISTERS 
BLOCK - INDEX 0 


Interrupt status information is provided by the In- 
terrupt Status register in the System Control 
Register block. This register returns information 
as to which part of the WD90C31A caused an 
interrupt. 


Reading this register does not reset any inter- 
rupts. Resetting of each interrupt is handled inde- 
pendently. 


Unassigned interrupts are returned as zeroes. 


2 ere 
8 | ept7 ace 
High when at least one of 
the interrupts 10 through 
7 is active 
ie. | Interrupt 6 active 
2 
Interrupt 1 active 
0 Aeyinerptisacve 
12.3.1 Global Interrupt Map 


1 VGA interrupt 
2 BITBLT interrupt 
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APPLICATION AND PROGRAMMING NOTES 


13.0 APPLICATION AND PROGRAMMING 


NOTES 


13.1 USE OF THE HARDWARE CURSOR IN 
16-BIT PER COLOR MODE 


The hardware cursor, while not specifically 
designed for hi-color mode operation, can still be 
used with certain limitations in that mode. 


The hardware cursor is unaware of the existence 
of hi-color mode but can still be used by specify- 
ing two adjacent 2-bit pixel codes for each high- 
color cursor pixel. A transparent hi-color pixel 
would be specified using two adjacent transparen- 
cy codes (1010), while a "color" hi-color pixel 
would usually be specified using adjacent primary 
and secondary color codes, such as 0100. The 
desired 16-bit cursor color would then be split be- 
tween the 8-bit primary and 8-bit secondary color 
registers. Inversion is also available as 1111 but 
the results might not be visually desirable. 


This limits the effective maximum cursor width in 
hi-color mode to 32 pixels. Further, the cursor 
origin and position are defined in terms of 8-bit, 
not the displayed 16-bit, pixels. Therefore, these 
values should be horizontal multiples of two. 


secondary and auxiliary color registers may be 
used to create additional cursor colors by mixing 
cursor codes within a 16-bit pixel region. It is im- 
portant to keep in mind the effects of inversion in 
systems that use one bit to switch between false 
color and hi-color modes on a pixel-by-pixel basis. 


13.2. BITBLT IN VGA MODES 4, 5, AND 6 


VGA modes 4, 5 and 6 are partially supported by 
the WD90C31A. Since these modes are not com- 
monly used in Windows, the additional hardware 
required to support the even/odd scan line offset 
technique employed in these modes is not sup- 
ported. 


However, a BITBLT operation in these VGA 
modes can often be broken up into two or three 
BLT operations, each of which operates on a con- 
tiguous area of memory. 


When the vertical offset between source and des- 
tination is an even number of rows, the desired 
operation can be broken into two BITBLTs, one for 
the even rows and one for the odd rows. This 
requires careful consideration of the register 


parameters, especially the BITBLT Dimension Y 
register. 


Where the offset is an odd number of rows, it may 
still be possible to break up the operation into only 
two BITBLTs, provided there is no overlap be- 
tween the source and destination regions. This is 
because information is being swapped between 
the even and odd scan line regions. 


Where source and destination do overlap, it may 
be possible to use a scratch space in off-screen 
memory and break up the operation into three 
BITBLTs. 


Another possibility is to break up a BITBLT into a 
series of one-line high operations that can be 
referred to as Line-BLTs. In this manner, a 
BITBLT may be simulated by the driver as a series 
of Line-BLTs. 


13.3. BITBLT OPERATIONS IN TEXT MODE 


BITBLT acceleration is available in VGA Text 
Modes. Text Mode BITBLTs generally consist of 
moving only character and attribute data (in maps 
0 and 1), while leaving the font data (in maps 2 
and 3) alone. The BITBLT mask is set to prevent 
update to those maps. For this reason, Planar 
(not Packed) Mode must be used. Similarly, the 
BITBLT mask can be set to move only character 
data, or only font data. 


Each display memory location consists of four 
bytes: one character, one attribute and two font 
plane bytes that are not part of the character but 
happen to fall in the same location as the charac- 
ter, but on maps 2 and 3. In planar mode, this is a 
space of eight pixels. Therefore, the source and 
destination of a character BLT must be multiples 
of eight. The X dimension is the number of char- 
acter columns to be copied times eight but the Y 
dimension is simply the unmultiplied number of 
character rows. The row pitch is set to the num- 
ber of characters per row times eight. 
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13.4 USE OF BITBLT IN 16-BIT PER COLOR 
MODE 


The BITBLT hardware can be used in 16-bit per 
color hi-color mode with a few changes and a few 
limitations. 


Hi-color BITBLTs should be performed in packed 
mode, remembering that each hi-color pixel takes 
up two adjacent normal packed pixels. The 
BITBLT Source and Destination registers should 
point to the first byte of the respective regions. 
Generally, the values in these register pairs are 
double the corresponding values for 256-color 
mode. 


In a right-to-left BITBLT in hi-color mode, the 
source and destination values must point to the 
second byte of each pixel. 


The BITBLT dimensions are twice the number of 
pixel columns, but the correct number of pixel 
rows. The Row Pitch register contains eight times 
the number of bytes between rows on the screen. 
Linear source and destination operate normally. 


Monochrome to color expansion or plane masking 
is not generally useable. Raster operations are 
available, but often produce undesired results. 
Similarly, color transparency is seldom useable. 


Pattern fills are available, however, the effective 
pattern is only 4 by 8 pixels. This may be useable 
where an 8 by 8 pattern is identical in the left and 
right halves. 


Filled rectangles are available in two ways. First, 
where the desired fill color is the same in the high 
and low bytes (generally meaning all black or all 
white), rectangle fill can be used normally. 


In the more general case of filling a rectangle with 
an arbitrary 16-bit color, the host should create a 4 
by 8 pattern of the fill color and use pattern fills to 
create the rectangle. 


Host I/O BITBLTs can operate normally be treating 
each 16-bit hi-color pixel as two adjacent, aligned 
8-bit packed mode pixels. 


Care should be used when implementing the use 
of one of the 16 bits in a hi-color pixel as a switch 
between false color and hi-color, since no mask 
exists to protect this flag bit during operations. 


WD90C31A 


13.5 USE OF BITBLT FOR ARBITRARY 
SIZED PATTERNS 


While the BITBLT hardware specifically ac- 
celerates 8 by 8 patterns, patterns of arbitrary size 
can be accelerated by use of the BITBLT, al- 
though to a lesser degree. 


To copy an arbitrary size pattern to a destination 
region, the pattern should be stored in non-visible 
memory as a rectangular region, not a linear strip. 
With destination update enabled, one copy of the 
pattern should be BITBLT’ed to the top-left corner 
of the destination. The BITBLT source is then set 
to point to the pattern now in the destination 
region. 


A series of BITBLTs are then performed, each 
doubling the width of the patterned area, simply 
by adjusting the X Dimensions register. (The last 
of this series of BITBLTs just fill out the destination 
region.) 


A new series of BITBLTs is then performed, taking 
the horizontally complete pattern and doubling it in 
height each time. The destination update should 
be turned off, and the destination must be set for 
each new BITBLT. The final BITBLT will probably 
not be a double of the previous one since it just 
fills out the region. 


13.6 PATTERNS BUILT ON-SCREEN 


Normally, a pattern to be used in BITBLT is stored 
in a non-visible portion of display memory. This 
requires an aligned strip of 32 or 64 bytes to be 
available. 


When this is not available, it may still be possible 
to perform a pattern BITBLT by placing the pattern 
in the last line of the destination region. This can 
be done if the raster operation is a Source copy or 
source inversion, and if the destination region can 
accommodate the specified aligned strip on a 
single line. This technique is possible because 
each row of the pattern is read at the beginning of 
the row in which it is used, and the pattern is not 
overwritten until it after it has been read for the 
last time. 


Where a full strip is unavailable, the destination 
can be broken up into a series of line-BLTs, with a 
one line pattern, requiring only 4 or 8 aligned 
bytes, placed on each destination line before the 
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BITBLT is started for that line. This method is sub- 
stantially slower than other pattern BITBLTs. 


A possible alternative is to write the pattern in a 
visible portion of memory, first saving the underly- 
ing area and restoring it after the BITBLT. This 
temporary usage of a visible region might be 
visible to the user. This might be reduced by 
using the last line of the destination and saving 
and restoring only those regions that overhang the 
destination. 


13.7 USE OF PATTERNS IN TEXT MODE 


Patterns may be in text mode to quickly set char- 
acter and/or attribute bytes in a rectangular area 
to a common value. A pattern space must be 
created containing eight consecutive copies of the 
four-byte area consisting of the character, the at- 
tribute and two Font Map bytes, all aligned to a 
64-pixel boundary. The BITBLT map mask is then 
used to protect the font maps. This pattern should 
be created in off-screen memory. 


If an off-screen pattern space is not available, one 
may be created on screen by loading an aligned 
group of eight character/attribute pairs within the 
destination area, then pointing to that as the pat- 
tern source. 


If the first character of the destination space hap- 
pens to be on an 8-byte boundary (such as the 
conventional top of screen) then, as long as the 
destination is at least eight characters wide, only 
the first character/attribute pair must be loaded, 
and the BITBLT operation creates its own pattern 
as it goes along. This also works if the destination 
is less than eight characters wide, but is still wider 
than it is high. 


If this is not possible, then the operation can be 
performed one character row at a time, loading 
the first character of each row to be used as an 
on-screen pattern. 


Filled rectangles have a very limited application in 
text mode, but could be used to clear out a sec- 
tion of a font map or to set a section of a character 
or attribute map to all zeroes or all ones. Different 
values are not easily set in this manner because, 
in order to protect the font maps, planar mode, 
rather than packed mode, must be used. 
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13.8 SUPPORT FOR KANJI CHARACTERS 


The BITBLT hardware can efficiently support 
generation of Kanji characters. The common im- 
plementation of Kanji characters calls for a char- 
acter box of 28 by 28 pixels, with five possible 
scoring lines for each character box. 


Kanji characters are best drawn in two passes. 
The first pass draws the characters while erasing 
any old ones. The second pass adds the score 
lines. 


The Kanji font should be stored in non-visible dis- 
play memory. Since the font is monochrome, mul- 
tiple characters can be stored one per plane, one 
under the other. The color compare registers are 
used to switch between banks of characters 
stored on different planes. 


A group of 32 special characters is generated 
along with the font, consisting of all possible com- 
binations of scoring lines. 


The dimension registers are loaded with the size 
of the character box. Foreground and background 
colors are set as desired. Destination update and 
quick BITBLTs are enabled. 


For each character row, the source and destina- 
tion registers are set to the beginning of the row, 
and monochrome expansion is enabled. A series 
of quick BITBLTs is performed, one per character, 
by loading the source address of each desired 
character. If a font-plane change is required 
before any character, it is done before loading the 
source registers, since these start the BITBLT 
automatically. 


After the character row is complete, the destina- 
tion registers are reset to the beginning of the row. 
Monochrome transparency is enabled, and a 
second pass is done over the character drawn to 
add score lines as needed, one special score-line 
character per Kanji character. 


Where a Kanji character requires no score lines, 
either a BITBLT of a special "blank" score-line 
character is performed, or the destination 
registers may be updated to skip the position. 
The driver may add additional intelligence to skip 
entire character rows or parts where score lines 
are not required. 
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13.9 VCLK AND MCLK RATIO FOR HIGH 
RESOLUTION MODES 


Support of the high resolution modes such as 
800X600X32K or 1024X768X256 at 70 or 72 Hz 
refresh rates is one of the strong features of the 
WD90C31A. However, careful attention needs to 
be paid to the MCLK and VCLK frequencies used 
in Supporting these modes. 


As described earlier, an internal FIFO interleaves 
CPU accesses and display refresh cycles. The 
FIFO is filled with data from the memory using the 
MCLK, and is emptied with a VCLK to produce the 
screen refresh. In high resolution modes, the 
video data output rate is very high due to the high 
VCLK frequencies involved. The MCLK for such 
modes must be appropriately high to keep the 
memory data fetch rate in balance with the output 
rates. If a slower MCLK is used, a FIFO under- 
flow will occur and will appear on the screen as 
white dashes in random places or as a shimmer. 


800X600X32K 
70 Hz 


VCLK MHz 
MCLK MHz 


VCLK/MCLK 
RATIO 


DRAM 
SPEED 


1024X768X256 
NON-INTERLACED | NON-INTERLACED 
60 Hz 





WD90C31A 


The WD90C31A is designed so that a ratio of 1.6 
or less must be maintained between the VCLK 
and MCLK. When the VCLK is 65 MHz or less, 
MCLK of 45 MHz or more can be used. However, 
MCLK of 50 MHz must be used for the high 
resolution modes with high refresh rates. Note 
that the DRAM rated at 60 ns or faster must also 
be used for the MCLK of 50 MHz so that the worst 
case memory timing specs are met. 


1024X768X256 1024X768X256 
NON-INTERLACED | NON-INTERLACED 
70 Hz 72 Hz 





TABLE 13-1. VCLK AND MCLK RATIO FOR HIGH RESOLUTION MODES 
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14.0 WD90C31A INTERFACES 


The WD90C31A applications section is divided able application notes and technical briefs at the 
into various interfaces: processor (AT or Micro — end of this document will supplement the informa- 
Channel mode), video memory, RAMDAC, __ tion provided in this section. 

monitor, and clock. The description and block an ee , 

diagrams are generic. No attempt is made to Figure 14-1 highlights the WD90C31A interfaces. 
present schematic level details. Currently avail- 


WD90C31A 


| > CONFIGURATION INTERFACE 


MA8/RAS1 
MA7:0] 
MD[31:0] 
WEO 


WE1 
. 8-BIT PC/AT WITH WE2 DRAM 1, 256K DRAM INTERFACE 
8-BIT BIOS WE3 INTERFACE 2. 512K DRAM INTERFACE 
. 16-BIT PC/AT WITH CPU RASS 3. 1M DRAM INTERFACE 


46-BIT PC/AT WITH ‘AS3 
16-BIT BIOS See , CAS 


_PC/AT VGA ROM BIOS _OE 
PAGE MAPPING RAS 


MDET 
EXVID 
EXPCLK 
VID[7:0] 1, RAMDAC INTERFACE 
PCLK VIDEO 2. MONITOR DETECT INTERFACE 
BLANK | INTERFACE 3. AUXILIARY VIDEO CONNECTOR 
_ CLOCK INTERFACE HSYNC 4. FEATURE CONNECTOR 
WITH INTERNAL MUX CLOCK VSYNC 
. EXTERNAL MUX 8:1 INTERFACE RPLT 
_ EXTERNAL MUX 4:1 WPLT 





FIGURE 14-1. WD90C31A INTERFACES 
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14.1. 8-BIT PC AT INTERFACE WITH 8-BIT 


BIOS 


Figure 14-2 shows a block diagram of the 


WD90C31A with eight-bit PC/AT interface using 


SA16 
A [23:0] 


SA [15:0] 


SD [7:0] 


RESET 
AEN 
REFRESH 
SMEMW 
SMEMR 
SIOR 
SIOW 
IRQ 





2/256-15 





ial 
aa iil 


244 


245 


G : DIR 


on 


WD9I0C3IA 


eight-bit BIOS. The system data bus SD(7:0) and 
address bus SA(19:0) are shown along with as- 
sociated buffers and BIOS ROM. 


WD90C31A 


EBROM 


6 
A [23:17] 


DIR 
EDBUFL 


RSET 
EIO 
EMEM 
MWR 
MRD 
lOR_ 
lIOW 
IRQ 
ALE 





FIGURE 14-2. 8-BIT PC AT INTERFACE WITH 8-BIT BIOS 
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14.2. 16-BIT PC AT INTERFACE WITH 8-BIT system address bus SA(19:0) are shown. As- 
BIOS sociated address and data bus buffers and BIOS 


Figure 14-3 illustrates 16-bit PC/AT interface with | ROM are also shown. 
an eight-bit BIOS using WD90C31A. For 386 sys- 
tems, the processor data bus SD(15:0), and the 


2/256-15 


WD90C31A 


SA16 
LA [23:17] 


SA [15:0] 


SD [7:0] 
SD [15:8] 


RESET 
AEN 
REFRESH 
SMEMW 
SMEMR 
SIOR 
SIOW 
IRQ 
SBHE 
MEMCS16 
lOCS16 


ALE 





FIGURE 14-3. 16-BIT PC AT INTERFACE WITH 8-BIT BIOS 
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14.3. 16-BIT PC AT INTERFACE WITH 16-BIT MEMCS16 implementation is limited to certain 
BIOS bus speeds since SA15 and SA16 are used for 


Figure 14-4 describes a 16-bit PC/AT interface the 16-bit BIOS. Refer to Figure 14-6 for 286- 
with 16-bit BIOS ROM implementation using the based systems. 

WD90C31A. The system data bus SD(15:0), ad- 

dress and data bus buffers are presented. Also, 





27256-15 27256-15 


WD90C31A 


EBROM 
DA [15:0] 
A16 


A [23:17] 





FIGURE 14-4. 16-BIT PC AT INTERFACE WITH 16-BiT BIOS 





-s 7 9/3/92 17-109 


WD90C31A WD90C31A INTERFACES 


14.4 16-BIT MICRO CHANNEL 


Figure 14-5 illustrates the WD90C31A and 16-bit 
Micro Channel interface. 3C3.D0 is output of Port 
3C3H Bit O VGA Subsystem Enable Register. 


WD90C31A 


SA16 Ai6 


SA [23:17] A [23:17] 
DA [15:0] 


SA [15:0] 


SD [7:0] 
SD [15:8] 


RESET 
3C3D0 

50 

M/iO 

S1 

CMD 

IRQ 

SBHE 
CDDS16 
CDSETUP 





FIGURE 14-5. 16-BIT MICRO CHANNEL INTERFACE 
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14.5 WD90C31A INTERFACE FOR 286 OR 
386 BASED SYSTEMS 


To interface the WD90C31A with an 8-bit and 16- 
bit AT bus, additional external logic is required as 
shown in the upper half of Figure 14-6. To inter- 


ALE 


A 
LA(23.20). B 
S 
A = 8-BIT | 
B = 16-BiT 
SA(19 17) A 
LA(19.17) B 
S 
A = 8-BIT 
B = 16-BiT 
SA16 


EABUF 


WD90C31A 


face the WD90C31A with only a 16-bit AT bus, the 
implementation illustrated in the lower half of Fig- 
ure 14-6 is recommended. 


WD90C31A 
+5V 
* MD8 
(CNF_11) Internal 
pull up 


Ai6 


DA(15:0) 





8 OR 16 BIT INTERFACE 


SA16 


WD90C31A 






Internal 
pull up 


16 BIT INTERFACE 


* Note: 


MD8 (CNF_11) Is pulled up internally at power-on-reset. 


LA(23:17) is internally latched by ALE. 


FIGURE 14-6. WD90C31A INTERFACE FOR 286 OR 386-BASED SYSTEMS 
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WEO, 










WE1 
OE 











MA8/RAS2 





RAS3 











RAS4 





WE2, WE3 






64k by 16 z 


aml 





VLEDO6GM 


SAOVAYALNI VLEQOEGM 
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WEO 
MD [7:0] 


WD90C31A 


OE 


WE1 


MD [15:8] 


MA [8:0] 


WE2 


MD [23:16] 


RAS 
CAS 


WE3 
MD [31:24] 





WD90C31A 


ol oo 

Pole : 
Po | 
| | i |) 256K by 4 
Eos 


Ue 
mine 
cctmeceniedge. 
eee AOR, 5 


Optional 





aE 


Note: Only MD [15:0] will be used if four 25K by 4 
DRAMs are installed. 


FIGURE 14-8. FOUR OR EIGHT 256K BY 4 DRAM INTERFACE 
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14.6 WD90C31A WITH RAMDAC INTERFACE 


Figure 14-9 illustrates the WD90C31A and RAM- 
DAC (WD90C50) interface block diagram for 
analog monitors. 


SD [7:0] 
SAO 
SA1 


VCC 
RAMDAC 


VREF 
FSADJ 


WD90C31A 


PCLK 
VID [7:0] 


BLANK 
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FIGURE 14-9. WD90C31A WITH RAMDAC INTERFACE 
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14.7. WD90C31A AND TTL MONITOR ¢ MD(15:12) may also be connected as the 
CONNECTIONS EGA switches if desired. See PR Register 

Figure 14-10 illustrates the WD90C31A and TTL and Pinout sections for more detail. 

monitor connections ¢ For AT applications using the WD90C31A, 





NOTE install the IRQ9 resistor. 

° VGA/T TL switch may be used to disable 
HSYNC and VSYNC for analog or TTL 
Video connector. 


¢ Transistor 2N2222A is used to emulate a 
monochrome and color display connection. 


WD90C31A 


TO VIDEO 
CONNECTOR 


HSYNC 
VSYNC 


SEC RED 

SEC GREEN/INTENS 
SEC BLUE/VIDEO 
RED 

GREEN 

BLUE 

GROUND 


‘© 2N2222A 
100 Q 


VCLK1 
/RESET 


36 MHZ 
28.322 MHZ 
25.175 MHZ 


16.257 MHZ ——___ 
os. 





FIGURE 14-10. WD90C31A AND TTL MONITOR CONNECTIONS 
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14.8 CLOCK INTERFACE The Configuration register Bit 3 (MD3) should be 


Figure 14-11 illustrates the WD90C31A with exter- tied low to make the WD90C31A signal pins 
nal oscillators at the clock pins configured as in-  (VCLK1, VCLK2) inputs. 

puts. The clock selection is determined by 

register 3C2H Bit 3 and Bit 2 and is described by 

the table below: 


3C2H | 3C2H CLOCK 
BIT3 | BIT2 | SELECTION 


ces 
haces 


VCLKO VCLK 
MCLK MCLK 

VCLK1 SELE 

VCLK2 VSEL2 VSELO 
USRO VSEL3  VSEL1 


WDS0C31A ICS90C63 





FIGURE 14-11. CLOCK INTERFACE 
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15.0 SHADOW REGISTER IMPLEMENTATION 


The Shadow register has been implemented for |The shadowed registers can be locked by writing 
some of the CRT Controller registers. The "XXXXX101" to PR1A(3?75.3D). This lock over- 
Shadow register makes it possible to have one _ rides any other locks. Then setting PR1A Bit 3 to 17 
CRT Controller register that may be written to and _—1 selects the Shadow register for read. 
read from at all times by application programs 

without changing CRT Controller timing. The ac- 

tual CRT Controller timing registers are initialized 

and locked while using the Shadow register for 

compatibility. 





HORIZONTAL TIMING 


ADDRESS | BITS LOCK DESCRIPTION 


Horizontal Total 


Start Horizontal Blanking 
End Horizontal Blanking 
Bit 6 of EHB 

Start Horizontal Retrace 
End Horizontal Retrace 
Display Enable Skew 
Horizontal Retrace Skew 


VERTICAL TIMING 


ADDRESS | BITS LOCK DESCRIPTION 


Vertical Total 

Bits 9, 8 of VT 
Vertical Retrace Start 
Bits 9, 8of VRS 
Vertical Retrace Start 
Start Vertical Blank 
Bit 8 of SVB 

Bit 9 of SVB 

End Vertical Blank 


Note: 

Group 0: Registers will be locked if PR3(5) = 1 or 375.11 bit 7 = 1 
Group 2: Registers will be locked if PR3(0) = 1 or 375.11 bit 7 = 1 
Group 3: Registers will be locked if PR3(0) = 

Group 0, 2, 3 registers listed above will be locked if 

PR1A = "xxxxx101", regardless of the contents of PR3. 

The Horizontal Display End and the Vertical Display End registers 
are not shadowed. 





TABLE 15-1. SHADOW REGISTER IMPLEMENTATION 
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16.0 SIGNATURE ANALYZER 


A signature analyzer is designed for use in the 
WD90C31A. The primary purpose of the signature 
analyzer is to aid in IC test and board level test. 
The signature analyzer allows the video output 
path to be included in diagnostics. Signature 
analysis is a method of compressing large 
amounts of data to be compared. Each video 
frame (video data and mode dependent) has a 
unique signature capable of detecting single bit 
errors. 


16.1 DESCRIPTION 


The basis of the signature analyzer is a Linear 
Feedback Shift Register (LFSR). The inputs to the 
LFSR tap onto the VID[7:0] output of the IC. The 
signal path of the video outputs is not modified by 
adding the signature analyzer. A block diagram is 
shown below. The primary variables in designing 
a signature analyzer are length of the shift register 
and the feedback terms to be used. The length 
will affect the probability of masking an error. The 
chance of masking an error is approximately 1/2", 
where n is the length of the shift register. A 16-bit 
signature register is used on the WD90C31A. 
Selection of an optimal feedback polynomial will 
depend on the type of errors expected. The CRC- 
CCITT polynomial (x'® + x'? 4 x° +1) has been 
implemented on the WD90C31A. It was modified 
for multiple inputs as shown in the block diagram. 


16.2 OPERATION 


The signature analyzer is designed to collect sig- 
nature of the VID[7:0] outputs over one vertical 
frame. The signal path of the VID[7:0] has not 
been altered. The signature analyzer register 
(LFSR) is enabled at the falling edge of the inter- 
nal VSYNC (before polarity selection) if the start 
bit is high. The following rising edge of the 
VSYNC signal will disable the LFSR. In the case 
of interlaced operation, signature is collected from 
the beginning of the even field to the end of the 
odd field. The signature analyzer contains a 4-bit 
control register PR19 (address 375.3F). Power- 
up-reset clears this register to OOH. This register 
has both read and write locks. The read lock 
Originates from PR10 Bits 7 and 3. The write lock 
Originates from PR10 Bits 2 through 0. PR10 also 
serves as the lock for other registers. 





FIGURE 16-1. LINEAR FEEDBACK SHIFT 
REGISTER 





17-118 9/3/92 


Ya 


SIGNATURE ANALYZER WD90C31A 


BIT | FUNCTION | READ/WRITE DESCRIPTION 


Start/status Writing "1" to this bit position enables the signature 
analyzer to collect a signature at the falling edge of the 
next vertical sync pulse. This bit may be read to check 
status if the read lock is disabled. 

1: Busy 

0: Finished or not enabled 














Writing "0" to this bit position preloads the LFSR with 
0001H. This bit must be set to operate the signature 
analyzer. 

1: Normal operation 

0: Preload LFSR 


Disable Video 
Input 










This bit is used in a self-test mode. A fixed signature will 
be generated for any given mode (independent of video 
memory data). 

1: Disable video inputs 

0: Enable video inputs 












Lock Read Port 





This bit must be set in order to read the signature and 

Status. 

1: Enable read of LFSR (addresses 375.20 and 
375.21). 

0: Disable reads of LFSR 


TABLE 16-1. CONTROL REGISTER PR19 


The following programming steps highlight the sequence that will setup, check, and read the signature. 
Step 1) 85H-> 375.29; release control register (PR10) read and write lock 

Step 2) OOH-> 375.3F; clear signature analyzer 

Step 3) O3H-> 375.3F; enable signature analyzer to collect signature 


Step 4) read 375.3F; check status for busy 
if LSB = 1 repeat step 4 
if LSB = 0 signature is collected, proceed to step 5 


Step 5) OAH-> 375.3F; enable signature analyzer read port 
Step 6) read 375.20; read low byte of signature 
Step 7) read 375.21; read high byte of signature 


Step 8) OOH-> 375.3F; clear signature analyzer and lock read port. 
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17.0 /O MAPPING 

17.1 INTRODUCTION 

The I/O Mapping is designed for use by the 
WD90C31A to isolate board level solder defects. 
The !/O Mapping allows the WD90C31A to enter a 
test mode where all pins in the WD90C31A are 
divided into various groups as inputs and outputs. 
The path from PCB trace through input, 
WD90C31A, output and PCB trace can be treated 
as a simple path. With test points on the board, a 
test for opens and shorts can be performed quickly. 


17.2 TEST MODE 
There are four requirements that must be met for 


the WD90C31A to enter the !/O mapping test 
mode: 

° MWR is LOW 

° IOR is LOW 


¢ CONFIGURATION SWITCH 2 is HIGH 
(MD2 is pulled high) 


° RESET is HIGH 


/O MAPPING 


If both MWR and IOR are low at the same time, it 
becomes an illegal condition in AT machines and 
a reserved condition in PS/2 machines. Con- 
figuration switch 2 high ensures that the 
WD90C31A is in AT mode. Reset controls a 
transparent latch as shown in Figure 17-1. Reset 
can be dropped low to latch the test mode. All the 
bidirectional pins are forced to input mode when in 
the test mode. 


17.3. PIN GROUPINGS 


The following pin groupings are done to minimize 
routing overhead of I/O pin mapping. Multiple 
input pins in a row are ORed together to the out- 
put shown in the following table. The input 
column lists the input pin number(s) along with the 
signal name(s). The output column lists the output 
pin number along with the pin name that cor- 
responds to the input pin(s). 





FIGURE 17-1. TEST MODE CIRCUIT 
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INPUT PINS OUTPUT PINS 


coma 
wd 


U 
—h, 


MDET 

MCLK 

MD31 

MD30 

MD29 + MD26 

MD28 + MD25 

MD27 

MD24 

P19 + P24 + P31 MD23 + MD18 + MD15 
P20 MD22 


P123 
P124 
P125 
P126 


VID4 
VIDS 
VID6 
VID7 
USR1 


vu 
aS 


UU; VU 
mak |: A 
O11; PO 


> 
5 


i) 
o) 
= 
> 
“J 


= 
> 


ball 


P10+P13 


P11+P14 P 


WM 
ms) 
Oo 


Uv 
“J 


GW] NM 


ms) 
> 
w 
re 


WE3 


P27 


0 
art 
o> 


P21 + P25 + P32 MD21 + MD17 +MD14 

P22 + P26 + P33 MD20 + MD16 + MD13 

P23 + P34 + P43 MD19+MD12+MD6 | P39 RAS 
P35 + P38 MD11 + MD8 P52 

P36 + P41 MD10 + CAS P53 

P37 + P42 +P46 MD9 + MD7 + MD3 P54 

P44 + P47 MD5 + MD2 P55 

P45 + P49 MD4 + MDO P56 

P48 + P62 MD1 +A17 P57 

P63 + P68 A18 + A22 P59 





P64 + P69 + P72 
p 
P66 + P73 + P86 A21 + ALE + ROM16 P61 


P70 + P77 + P80 lIOCS16 + IOW + P74 
RESET 


P90 + P93 + P95 DA15 + DA12 + DA10 + 


P79 + P89 MWR + A16 


P75 + P78 + P88 EMEM + MRD + P82 lOCHRDY 
EDBUFH 


A19+A23+8B 


mM 
> 
on 


‘© 
O1 





8 





P71 MEMCS16 


TABLE 17-1. WD90C31A PIN SCAN MAP FOR 132-PIN PACKAGE 
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WDI0C3IA I/O MAPPING 


INPUT PINS OUTPUT PINS 


ew ae 


Note: 
A"+" in the input column indicates an OR function for the test input pins only. 
** This mapping for DIR output is valid only during RESET HIGH. 


WS 
EBROM 
RPLT 

PLT 
HTL 
HSYNC 
PLCK 
VIDO 
VID1 
VID2 
ID3 





TABLE 17-1. WD90C31A PIN SCAN MAP FOR 132-PIN PACKAGE (Continued) 
Refer to Table 4-3 for the comparable pin number for a 144-pin package. 
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EA EDBUFF 
MTS IS ESRon 
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FIGURE 17-2. WD90C31A PIN SCAN MAP FOR A 132-PIN PACKAGE 
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18.0 DC ELECTRICAL SPECIFICATIONS 
18.1. MAXIMUM RATINGS | 
Voltage on any pinwith respecttoVss .. |... _ 0.3 to 7 Volts 


Ambient Temperature Under Bias ...... . . .0°C to 70°C (32°F to 158°F) 
Storage Temperature... ....... =. . . . -40°C to 125°C (-40°F to 257°F) 
NOTE 


Stresses above those listed under Absolute Maximum Ratings may cause per- 
manent damage to the device. This is a stress rating only and functional opera- 
tion of the device at these or any other conditions above those indicated in the 
operational section of the specification, is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect product reliability. 


18.2 STANDARD TEST CONDITIONS 


The characteristics below apply for the following standard test conditions, unless otherwise noted. All 
voltages are referenced to Vss (OV Ground). Positive current flows into the referenced pin. 


Operating Temperature Range... ..... .... . 0°C to 70°C (32°F to 158°F) 
Power Supply Voltage ne & 2 we em oe wm & & & -ae75 109.25. Volis 
Power Dissipation . ...... .. . . . . . . 140 mA 


18.3 DC CHARACTERISTICS 


Pins MDET, BHE, EXVID, EXPCLK, MD31:0, DA15:0 and VCLK2 have internal pullup resistors with a 
minimum pullup resistance of 50KQ. 


With the following exceptions the WD90C31A outputs have 2.0 mA maximum source and sink capability. 
IRQ, IOCHRDY, OWS, MEMCS16, lOCS16 = 24 mA sink. 

PCLK, VID7:0, BLANK = 8 mA source/sink. 

DRAM Interface = 4.0 mA source/sink(RAS, CAS, WE, OE, MA, MD) 

HSYNC, VSYNC, DA15:0 = 6 mA sink. 

ROM(16 = 16 mA sink. 


fe ee ee ee 


Inout Low Voltage VCC = 5V +5% 
Input High Voltage : VCC = 5V +5% 
Input Low Current a VIN = 0.0V 
Input High Current ote VIN = VCC 
Output Low Voltage - IOL +2.0 mA 


Output High Voltage IOH = -2.0 mA 


High Impedance . OV<VOUT<VCC 
Leakage Current 


Input Capacitance - F=1 MHz 
Output Capacitance F = 1 MHz 
I/O Pin Capacitance F =1 MHz 





TABLE 18-1. DC CHARACTERISTICS 
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19 .0 AC TIMING CHARACTERISTICS 


The following notes apply to all of the parameters ¢ ntimplies n X t, (n times the period t). 

presented in this section: e.g. it, 2t etc. 
° All units are in nanoseconds. ¢ #n refers to the spec number in column 1 17 
¢ CL = 30 pF unless otherwise noted. of the same table. 


NUMBER CHARACTERISTIC TEST CONDITION 


RESET TIMING. 


RESET Pulse Width t=1/MCLK (For 
MD Setup to RESET low configuration at 
MD Hold from RESET low power up.) 
RESET low to first IOW 


CLOCK TIMING 


VCLK period Note 1 

VCLK high At 1/2 VDD 

VCLK low At 1/2 VDD 

Clock rise time Note 1 1V - (VDD - 1V) 

Clock fall time Note 1 1V - (VDD - 1V) 

VCLK to PCLK delay 45 ns at 120 pF 
load 

VCLK to HSYNC delay 

VCLK to VSYNC delay 

VCLK to BLANK delay | 

VCLK to VID(7:0) delay 45 ns at 120 pF 
load up to 30 MHz 

MCLK period Max 50 MHz, 
Min 33.3 MHz 

MCLK high At 1/2 VDD 

MCLK low At 1/2 VDD 

VID (7:0) setup to PCLK 

VID (7:0) hold from PCLK 


Note 1 - Apply to both VCLK and MCLK. 
Note 2 - VCLKO and MCLK use CMOS level input buffers. V(IL) max = 1.5 V, V(IH) mn = VDD - 1.5 V 





TABLE 19-1. AC TIMING CHARACTERISTICS 
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NUMBER CHARACTERISTIC MIN MAX | TEST CONDITION 
VO AND MEMORY READ/WRITE AT MODE TIMING 























1 EMEM setup to MRD, MWR low 20 
2 EMEM hold from MRD, MWR high 10 
3a A(23:17) setup to ALE low 20 
3b BHE, DA(15:0) setup to IOR, IOW, MRD, 18 
MWR low 
4a A(23:17) hold from ALE low 10 
Ab DA(15:0) hold from IOR, |OW, MRD, MWR 10 
low 
5 EIO setup to IOR/IOW low 20 
6 EIO hold from IOR/JOW high 10 
7a EABUF high from IOR, IOW, MRD, MWR low | 9 25 
7b EDBUF low from IOR, IOW, MRD, MWR low | 13.5 35 
7c HTL low from MRD low 25 
8a EABUF low from IOR, IOW, MRD, MWR high _ | 14.5 35 
8b EDBUF high from IOR, iow, MRD, MWR high | 8.5 25 
8c HTL high from MRD high 25 
9 DIR high from IOR, MRD low 20 
10 DIR hold from IOR and MRD high 20 
11 DA(15:0) write data setup to |OW, MWR high | 20 
12a DA(15:0) read data hold from IOR high or 10 
MRD high 
12b DA(15:0) write data hold from IOW, MWR high | 10 
13 DA(15:0) read data valid after IOR low 70 
14 RDY high from MWR/MRD low 10 2.45 us 
(max is for standard VGA modes) 
15 Memory read data valid from RDY high 40 Note 3 
16a RDY low from MWR/MRD low 10 25 Ci = 100 pF 
16b RDY low from IOW, IOR low 10 25 Ci = 100 pF 
17a RDY tristate from MWR/MRD high 10 30 Ci = 100 pF 
17b RDY tristate from IOW, IOR high 10 30 Ci. = 100 pF 
18 EBROM low from valid A(23:15) 40 
19 EBROM hold from MRD high 40 
20a WPLT low from IOW low 37 
20b RPLT low from IOR low 30 


Note 3 Depends on setting of PR31 (8C5H, Index 11H) bits 4, 3. t= "/MCLK 
00 max 40 ns 
O01 max 40ns + it 
10 max 40 ns +2t 
11. max 40 ns - It 
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AC TIMING CHARACTERISTICS WD9I0C3I1A 


NUMBER CHARACTERISTIC MIN | MAX | TEST CONDITION 
/O AND MEMORY READ/WRITE AT MODE TIMING (Continued) 


WPLT high from IOW high 9 15 

RPLT high from IOR high 9 20 

EBROM low from IOW low (46E8H port) 1t+ 20 

EBROM high from IOW high (46E8H port) 25 

VCLK1 low from IOW low (3C2H port) 1t+ 24 

VCLK1 high from IOW high (3C2H port) 15 

A(15:0) valid to |OCS16 low 35 C._ = 100pF 














































IOCS16 hold from IOW high 20 Ci = 100pF 
A(23:17) valid to MEMCS16 or ROM16 low 41 CL = 100pF 
MEMC$16 tristate from the next active ALE 39 CL = 100pF 

IOR, IOW, MWR, MRD high 2t+15 t = '/MCLK Note 4 
IOR, OW, MWR, MRD low ot t='/MCLK Note 5 
ALE pulse width 30 

OWS, low from IOW, MWR low 15 CL = 100pF 








Depends on setting of PR31 (3C5H, Index 11H) bits 4, 3. t= '/MCLK 
0O max 40ns 

O01 max 40 ns + it 

10 max 40 ns + 2t 

11. max 40 ns - it 





Minimum of #30a should be the greater of 2t + 15 or (#8a + #3b + delay on the external 
address buffer) 


Minimum of #30b should be the greater of 2t or (#7b + #11 + delay on the external data 
buffer) 
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WD9I0C31A AC TIMING CHARACTERISTICS 


NUMBER CHARACTERISTICS MIN MAX | TEST CONDITION 


VO AND MEMORY READ/WRITE MICRO CHANNEL MODE TIMING 



































1 A(23:0),EMEM,BHE setup to CMD low 20 
2 A(23:0),EMEM,BHE hold from CMD low 10 
3 CDSETUP,EIO setup to CMD low 20 
4 CDSETUP,EIO hold from CMD low 15 
5 STATUS setup to CMD low 20 
6 STATUS hold from CMD low 15 
7a EDBUFH, EDBUFL low from CMD low 13.5 35 
7b EABUF high from CMD low 9 25 
8a EDBUFH, EDBUFL high from CMD high 8.5 25 
8b EABUF low from CMD high 14.5 35 
9 DIR active from CMD low 20 
10 DIR inactive from CMD high 20 
11 CSFB delay from valid address/status 30 C_ = 100 pF 
12 CSFB hold from CMD high (I/O cycle) 30 C. = 100 pF 
13 CSFB hold from invalid address (memory 
cycle) 30 CL = 100 pF 
14 CDDS16 delay from valid address 40 
15 CDDS16 hold from invalid address 30 
16 DA(15:0) write data setup to CMD high 20 
17 DA(15:0) Write data hold after CMD high 10 
18 DA(15:0) I/O Read data valid from CMD low 70 
19 RDY high delay from CMD low 0 2.45 us 
20 DA(15:0) Memory Read Data valid from RDY 40 Note 3 
high 
21a CMD high (inactive) 2t+15 Note 6 
21b CMD low at Note 7 
22 RDY low delay from valid address/status 30 
23 EBROM low from valid address 40 
24 EBROM high from CMD high 30 
25 WPLT /RPLT low from CMD low 9 20 
26 WPLT /RPLT high from CMD high 9 20 
27 VCLK1 low from CMD low (3C2H port) 1t + 30 
28 VCLK1 high from CMD high (3C2H port) 25 


Note3 Depends on setting of PR31 (3C5H, Index 11H) bits 4, 3. t= 'MCLK 
OO max 40 ns 
O1 max 40ns + It 
10 max 40 ns + 2t 
11. max 40 ns - It 


Note 6 Minimum of #21a is the greater of 2t + 5 or (#8b + #1 + delay on external address buffer) 


Note 7 Minimum of #21b is the greater of 2t or (#7a + #16 + delay on external data buffer) 
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AC TIMING CHARACTERISTICS 


NUMBER 


OOnN Ooh WND — 


CHARACTERISTIC 


DRAM TIMING (256K By 4, 256K By 16) 


RAS cycle time 

RAS pulse width low 

RAS high time (precharge) 

RAS low to CAS low 

CAS cycle time 

CAS pulse width low 

CAS high time (precharge) 

Row address setup to RAS low 
Row address hold time from RAS low 
Column address setup to CAS. low 
Column address hold from CAS low 
Read Data valid before CAS high 
Read Data hold after CAS high 
Write Data setup to CAS low 


Write Data hold after CAS low 


: MIN 


6t 
3.5t-d 
2.5t+d 
2.5t-9 
at 
1t+d 
1t-d 
1t- 10 
It 

1t- 10 
1t 

3 

0 

1t- 15 
0.5t+5 


MAX 


2.5t-d 


1t+5 


WD90C31A 


TEST CONDITION 


Note 8 
Note 8 
Note 8 
Note 8 


Note 8 
Note 8 





WE low setup CAS low 1t-5 
WE low hold after CAS. high Same as 
CAS low 
2t- 10 
1t- 10 
1t- 10 
1.5t+ 10 


OE high before WE low 

OE low after WE high 

CAS high for CAS before RAS refresh 

RAS low from CAS low for CAS before RAS 
refresh 


The timing is the result of setting PR33 (3C5, Index = 13) = XXX00000. 
Timings are adjustable by PR33. 
Memory write uses fast page early write, while keeping OE = 1. 
Memory read uses fast page read, while keeping OE = 1. 
t= '/MCLK 
(MCLK = 37.5 MHz for 80 ns DRAM) 
(MCLK = 40 MHz for some faster 80ns DRAM) 
(MCLK = 44.4 MHz for 70 ns DRAM) 
(MCLK = 49.5 MHz for 60 ns DRAM) 
d = Delay of between 4 and 7 ns. 


Maximum MCLK frequency 


Note 9 
0.5t refers to the high pulse width of the MCLK measured at 2.5V. 
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WD9I0C31A AC TIMING CHARACTERISTICS 


NUMBER CHARACTERISTIC MIN | MAX TEST CONDITION 
DRAM TIMING (64K by 16) 


RAS cycle time Note 10 
RAS pulse width low Note 10 
RAS high time (precharge) Note 10 
RAS low to CAS low Note 10 
CAS cycle time 

CAS pulse width low Note 10 
CAS high time (precharge) Note 10 
Row address setup to RAS low 

Row address hold time from RAS low 

Column adress setup to CAS low 

Column address hold from CAS low 

Read Data valid before CAS high 

Read Data hold after CAS high 

Write Data setup to CAS low 

Write Data hold after CAS low 

WE low setup before CAS low 

WE low hold after CAS high 


OOnNOOBRWND — 


OE high before WE low 

OE low after WE high 

CAS high for CAS before RAS refresh 

RAS low from CAS low for CAS before RAS 
refresh 


0.5t refers to the high pulse width of the MCLK measured at 2.5V. 


MCLK edge to RAS, CAS, MA(8:0) edge delay may be up to 40 ns. 


Note 10 

The timing is the result of setting PR33 (8C5H, Index = 13H) = xxx01110. 
Timings are adjustable by PR33. 

Memory write uses fast page early write, while Keeping OE = 1. 

Memory read uses fast page read, while keeping OE = 0. 

t= '/MCLK (MCLK = 36 MHz for 80 ns, 64K by 16 DRAM). 

d = Delay of between 4 and 7 ns. 
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AC TIMING CHARACTERISTICS WD90C31A 





FIGURE 19-1. RESET TIMING 
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FIGURE 19-2. CLOCK AND VIDEO TIMING 
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WD90C31A 


AC TIMING CHARACTERISTICS 
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FIGURE 19-3. AT MODE BUS TIMING 
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AC TIMING CHARACTERISTICS 
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FIGURE 19-4. MICRO CHANNEL MODE BUS TIMING 
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Minimum RAS precharge adjustment 


(1) PR_33 (3C5 Index 13) Bit 1,0 
(2) PR_33 (3C5 Index 13) Bit 1,0 
(3) PR_33 (3C5 Index 13) Bit 1,0 
(4) PR_33 (3C5 Index 13) Bit 1,0 


(1) PR_33 (3C5 Index 13) Bit 2 
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RAS high time (minimum precharge) = 2.5t + d 
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WD9I0C3IA 


DRAM Timing Adjustment: The RAS, CAS timing 
can be adjusted by register PR33 (3C5H, Index 
3H) bits 4 through 0. Only the following timing 
may be affected: (See Figures 19-5 and 19-6). 


3 RAS high time (precharge) 
4 RAS low to CAS low 
6 CAS pulse width 


AC TIMING CHARACTERISTICS 


CAS pulse width adjustment: CAS cycle time is 
always equal to 2t {t = 1/MCLK}, {d = (4~ 8) ns}. 


PR33 (Bits_4 through 3) = 


00, CAS low = 1t +d; CAS high = 1t-d 
01, CAS low = It + 2d; CAS high = 1t - 2d 
1X, CAS low = 1.5t; CAS high = '/2t 


~ 


PR33 = xxx00000 





FIGURE 19-7. 256K BY 4 DRAM TIMING 





PR33 = xxx01110 


FIGURE 19-8. 64K BY 16 DRAM TIMING 





17-136 


9/3/92 


PACKAGE DIMENSIONS 


20.0 PACKAGE DIMENSIONS 


Figure 20-1 illustrates the 132-pin PQFP package 
showing the dimensions in inches. Figure 20-2 
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WD90C3IA 


illustrates the 144-pin MQFP package showing 
the dimensions in millimeters and inches. 


035 MIN 


Detail of the bumper with the 
lead already cut and formed 


Lead configuration 
after cut & forming 


014 MAX 


068 MIN 
BEE aes 


ds elke 008/ 010 


OPTION - C - 


+ 004 
_ 000 


OPTION - B - 


FIGURE 20-1. 132-PIN PQFP PACKAGE 
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WD9I0C3IA PACKAGE DIMENSIONS 


SEATING 
PLANE 
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D6 
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FIGURE 20-2. 144-PIN MQFP PACKAGE \ 
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